From 9f95ff5b6ba01db09552b84a0ab79607060a2666 Mon Sep 17 00:00:00 2001 From: Ali Labbene Date: Wed, 11 Dec 2019 08:59:21 +0100 Subject: Official ARM version: v5.4.0 Add CMSIS V5.4.0, please refer to index.html available under \docs folder. Note: content of \CMSIS\Core\Include has been copied under \Include to keep the same structure used in existing projects, and thus avoid projects mass update Note: the following components have been removed from ARM original delivery (as not used in ST packages) - CMSIS_EW2018.pdf - .gitattributes - .gitignore - \Device - \CMSIS - \CoreValidation - \DAP - \Documentation - \DoxyGen - \Driver - \Pack - \RTOS\CMSIS_RTOS_Tutorial.pdf - \RTOS\RTX - \RTOS\Template - \RTOS2\RTX - \Utilities - All ARM/GCC projects files are deleted from \DSP, \RTOS and \RTOS2 Change-Id: Ia026c3f0f0d016627a4fb5a9032852c33d24b4d3 --- docs/NN/html/CIFAR10_CNN.gif | Bin 0 -> 29414 bytes docs/NN/html/CMSIS-NN-OVERVIEW.PNG | Bin 0 -> 14206 bytes docs/NN/html/CMSIS_Logo_Final.png | Bin 0 -> 12402 bytes docs/NN/html/ChangeLog_pg.html | 147 ++ docs/NN/html/GRU.gif | Bin 0 -> 14771 bytes docs/NN/html/annotated.html | 140 ++ docs/NN/html/annotated.js | 5 + ...convolve__1x1__HWC__q7__fast__nonsquare_8c.html | 138 ++ .../NN/html/arm__convolve__HWC__q15__basic_8c.html | 138 ++ docs/NN/html/arm__convolve__HWC__q15__fast_8c.html | 138 ++ ...rm__convolve__HWC__q15__fast__nonsquare_8c.html | 138 ++ docs/NN/html/arm__convolve__HWC__q7__RGB_8c.html | 138 ++ docs/NN/html/arm__convolve__HWC__q7__basic_8c.html | 138 ++ ...rm__convolve__HWC__q7__basic__nonsquare_8c.html | 138 ++ docs/NN/html/arm__convolve__HWC__q7__fast_8c.html | 138 ++ ...arm__convolve__HWC__q7__fast__nonsquare_8c.html | 138 ++ ...rm__depthwise__separable__conv__HWC__q7_8c.html | 138 ++ ...se__separable__conv__HWC__q7__nonsquare_8c.html | 138 ++ ...rm__fully__connected__mat__q7__vec__q15_8c.html | 138 ++ ...ully__connected__mat__q7__vec__q15__opt_8c.html | 138 ++ docs/NN/html/arm__fully__connected__q15_8c.html | 138 ++ .../html/arm__fully__connected__q15__opt_8c.html | 138 ++ docs/NN/html/arm__fully__connected__q7_8c.html | 138 ++ .../NN/html/arm__fully__connected__q7__opt_8c.html | 138 ++ docs/NN/html/arm__nn__activations__q15_8c.html | 138 ++ docs/NN/html/arm__nn__activations__q7_8c.html | 138 ++ .../arm__nn__mat__mult__kernel__q7__q15_8c.html | 221 +++ ...__mat__mult__kernel__q7__q15__reordered_8c.html | 220 +++ docs/NN/html/arm__nn__mult__q15_8c.html | 138 ++ docs/NN/html/arm__nn__mult__q7_8c.html | 138 ++ docs/NN/html/arm__nn__tables_8h.html | 240 +++ docs/NN/html/arm__nnexamples__cifar10_8cpp.html | 416 +++++ .../html/arm__nnexamples__cifar10__inputs_8h.html | 150 ++ .../arm__nnexamples__cifar10__parameter_8h.html | 724 ++++++++ .../html/arm__nnexamples__cifar10__weights_8h.html | 408 +++++ docs/NN/html/arm__nnexamples__gru_8cpp.html | 531 ++++++ .../html/arm__nnexamples__gru__test__data_8h.html | 304 ++++ docs/NN/html/arm__nnfunctions_8h.html | 429 +++++ docs/NN/html/arm__nnsupportfunctions_8h.html | 208 +++ docs/NN/html/arm__nntables_8c.html | 268 +++ docs/NN/html/arm__pool__q7__HWC_8c.html | 141 ++ docs/NN/html/arm__q7__to__q15__no__shift_8c.html | 138 ++ .../arm__q7__to__q15__reordered__no__shift_8c.html | 138 ++ docs/NN/html/arm__relu__q15_8c.html | 138 ++ docs/NN/html/arm__relu__q7_8c.html | 138 ++ docs/NN/html/arm__softmax__q15_8c.html | 138 ++ docs/NN/html/arm__softmax__q7_8c.html | 138 ++ docs/NN/html/bc_s.png | Bin 0 -> 676 bytes docs/NN/html/bdwn.png | Bin 0 -> 147 bytes docs/NN/html/cifar10_2readme_8txt.html | 129 ++ docs/NN/html/classes.html | 143 ++ docs/NN/html/closed.png | Bin 0 -> 132 bytes docs/NN/html/cmsis.css | 1282 ++++++++++++++ .../html/dir_06560e3359c5da94845158f0031c08e8.html | 139 ++ .../html/dir_13dc9928808d08450b31fdaf572dfc8e.html | 145 ++ .../html/dir_17aeddf785065efc95337b880bac512b.html | 139 ++ .../html/dir_1c6ec18b156ae6affcf9513e9ed30cbf.html | 135 ++ .../html/dir_21d6d99be497a80d1e903a1ff5a6bb5a.html | 141 ++ .../html/dir_42ee8ba91ca7a55df66538ce31ddec49.html | 135 ++ .../html/dir_44941783335eeef51fdbcde02b124fbf.html | 159 ++ .../html/dir_4ad8c19a899a351ef23a1c3a29886c7d.html | 143 ++ .../html/dir_5c060210645429de182d0ec8a79ad82d.html | 141 ++ .../html/dir_6d5f4079ba9c4513aa4d8d5ca02967b4.html | 135 ++ .../html/dir_8e33b5b68f9112312341506c184d7434.html | 145 ++ .../html/dir_8ff992d4a3d8f0c2e6b3f2d3952b972b.html | 137 ++ .../html/dir_a3a0a3f0894883b6608166441e8c3ad3.html | 139 ++ .../html/dir_b7d5e60e0ec4c139f7aa9a155c284f70.html | 137 ++ docs/NN/html/doxygen.css | 1366 +++++++++++++++ docs/NN/html/doxygen.png | Bin 0 -> 3779 bytes docs/NN/html/dynsections.js | 97 ++ docs/NN/html/files.html | 173 ++ docs/NN/html/ftv2blank.png | Bin 0 -> 86 bytes docs/NN/html/ftv2cl.png | Bin 0 -> 453 bytes docs/NN/html/ftv2doc.png | Bin 0 -> 746 bytes docs/NN/html/ftv2folderclosed.png | Bin 0 -> 616 bytes docs/NN/html/ftv2folderopen.png | Bin 0 -> 597 bytes docs/NN/html/ftv2lastnode.png | Bin 0 -> 86 bytes docs/NN/html/ftv2link.png | Bin 0 -> 746 bytes docs/NN/html/ftv2mlastnode.png | Bin 0 -> 246 bytes docs/NN/html/ftv2mnode.png | Bin 0 -> 246 bytes docs/NN/html/ftv2mo.png | Bin 0 -> 403 bytes docs/NN/html/ftv2node.png | Bin 0 -> 86 bytes docs/NN/html/ftv2ns.png | Bin 0 -> 388 bytes docs/NN/html/ftv2plastnode.png | Bin 0 -> 229 bytes docs/NN/html/ftv2pnode.png | Bin 0 -> 229 bytes docs/NN/html/ftv2splitbar.png | Bin 0 -> 314 bytes docs/NN/html/ftv2vertline.png | Bin 0 -> 86 bytes docs/NN/html/functions.html | 147 ++ docs/NN/html/functions_vars.html | 147 ++ docs/NN/html/globals.html | 674 ++++++++ docs/NN/html/globals_defs.html | 400 +++++ docs/NN/html/globals_enum.html | 139 ++ docs/NN/html/globals_eval.html | 142 ++ docs/NN/html/globals_func.html | 319 ++++ docs/NN/html/globals_vars.html | 272 +++ docs/NN/html/group__Acti.html | 327 ++++ docs/NN/html/group__Acti.js | 7 + docs/NN/html/group__CNNExample.html | 160 ++ docs/NN/html/group__FC.html | 755 ++++++++ docs/NN/html/group__FC.js | 9 + docs/NN/html/group__GRUExample.html | 162 ++ docs/NN/html/group__NNBasicMath.html | 261 +++ docs/NN/html/group__NNBasicMath.js | 5 + docs/NN/html/group__NNConv.html | 1796 ++++++++++++++++++++ docs/NN/html/group__NNConv.js | 14 + docs/NN/html/group__Pooling.html | 321 ++++ docs/NN/html/group__Pooling.js | 5 + docs/NN/html/group__Softmax.html | 233 +++ docs/NN/html/group__Softmax.js | 5 + docs/NN/html/group__groupNN.html | 146 ++ docs/NN/html/group__groupNN.js | 8 + docs/NN/html/group__nndata__convert.html | 242 +++ docs/NN/html/group__nndata__convert.js | 5 + docs/NN/html/gru_2readme_8txt.html | 129 ++ docs/NN/html/history_8txt.html | 129 ++ docs/NN/html/index.html | 163 ++ docs/NN/html/jquery.js | 72 + docs/NN/html/modules.html | 142 ++ docs/NN/html/modules.js | 8 + docs/NN/html/namespacemembers.html | 181 ++ docs/NN/html/namespacemembers_func.html | 139 ++ docs/NN/html/namespacemembers_vars.html | 175 ++ docs/NN/html/namespacepara__gen.html | 373 ++++ docs/NN/html/namespaces.html | 133 ++ docs/NN/html/nav_f.png | Bin 0 -> 153 bytes docs/NN/html/nav_g.png | Bin 0 -> 95 bytes docs/NN/html/nav_h.png | Bin 0 -> 98 bytes docs/NN/html/navtree.css | 143 ++ docs/NN/html/navtree.js | 536 ++++++ docs/NN/html/navtreeindex0.js | 55 + docs/NN/html/open.png | Bin 0 -> 123 bytes docs/NN/html/pages.html | 133 ++ docs/NN/html/para__gen_8py.html | 177 ++ docs/NN/html/printComponentTabs.js | 39 + docs/NN/html/resize.js | 97 ++ docs/NN/html/search/all_0.html | 26 + docs/NN/html/search/all_0.js | 78 + docs/NN/html/search/all_1.html | 26 + docs/NN/html/search/all_1.js | 5 + docs/NN/html/search/all_10.html | 26 + docs/NN/html/search/all_10.js | 4 + docs/NN/html/search/all_11.html | 26 + docs/NN/html/search/all_11.js | 5 + docs/NN/html/search/all_2.html | 26 + docs/NN/html/search/all_2.js | 42 + docs/NN/html/search/all_3.html | 26 + docs/NN/html/search/all_3.js | 6 + docs/NN/html/search/all_4.html | 26 + docs/NN/html/search/all_4.js | 4 + docs/NN/html/search/all_5.html | 26 + docs/NN/html/search/all_5.js | 6 + docs/NN/html/search/all_6.html | 26 + docs/NN/html/search/all_6.js | 12 + docs/NN/html/search/all_7.html | 26 + docs/NN/html/search/all_7.js | 17 + docs/NN/html/search/all_8.html | 26 + docs/NN/html/search/all_8.js | 4 + docs/NN/html/search/all_9.html | 26 + docs/NN/html/search/all_9.js | 10 + docs/NN/html/search/all_a.html | 26 + docs/NN/html/search/all_a.js | 5 + docs/NN/html/search/all_b.html | 26 + docs/NN/html/search/all_b.js | 17 + docs/NN/html/search/all_c.html | 26 + docs/NN/html/search/all_c.js | 11 + docs/NN/html/search/all_d.html | 26 + docs/NN/html/search/all_d.js | 9 + docs/NN/html/search/all_e.html | 26 + docs/NN/html/search/all_e.js | 10 + docs/NN/html/search/all_f.html | 26 + docs/NN/html/search/all_f.js | 11 + docs/NN/html/search/classes_0.html | 26 + docs/NN/html/search/classes_0.js | 4 + docs/NN/html/search/close.png | Bin 0 -> 273 bytes docs/NN/html/search/defines_0.html | 26 + docs/NN/html/search/defines_0.js | 36 + docs/NN/html/search/defines_1.html | 26 + docs/NN/html/search/defines_1.js | 6 + docs/NN/html/search/defines_2.html | 26 + docs/NN/html/search/defines_2.js | 7 + docs/NN/html/search/defines_3.html | 26 + docs/NN/html/search/defines_3.js | 16 + docs/NN/html/search/defines_4.html | 26 + docs/NN/html/search/defines_4.js | 4 + docs/NN/html/search/defines_5.html | 26 + docs/NN/html/search/defines_5.js | 15 + docs/NN/html/search/defines_6.html | 26 + docs/NN/html/search/defines_6.js | 6 + docs/NN/html/search/defines_7.html | 26 + docs/NN/html/search/defines_7.js | 8 + docs/NN/html/search/enums_0.html | 26 + docs/NN/html/search/enums_0.js | 4 + docs/NN/html/search/enumvalues_0.html | 26 + docs/NN/html/search/enumvalues_0.js | 5 + docs/NN/html/search/files_0.html | 26 + docs/NN/html/search/files_0.js | 43 + docs/NN/html/search/files_1.html | 26 + docs/NN/html/search/files_1.js | 4 + docs/NN/html/search/files_2.html | 26 + docs/NN/html/search/files_2.js | 4 + docs/NN/html/search/files_3.html | 26 + docs/NN/html/search/files_3.js | 4 + docs/NN/html/search/files_4.html | 26 + docs/NN/html/search/files_4.js | 4 + docs/NN/html/search/functions_0.html | 26 + docs/NN/html/search/functions_0.js | 34 + docs/NN/html/search/functions_1.html | 26 + docs/NN/html/search/functions_1.js | 5 + docs/NN/html/search/functions_2.html | 26 + docs/NN/html/search/functions_2.js | 4 + docs/NN/html/search/functions_3.html | 26 + docs/NN/html/search/functions_3.js | 4 + docs/NN/html/search/groups_0.html | 26 + docs/NN/html/search/groups_0.js | 4 + docs/NN/html/search/groups_1.html | 26 + docs/NN/html/search/groups_1.js | 4 + docs/NN/html/search/groups_2.html | 26 + docs/NN/html/search/groups_2.js | 4 + docs/NN/html/search/groups_3.html | 26 + docs/NN/html/search/groups_3.js | 4 + docs/NN/html/search/groups_4.html | 26 + docs/NN/html/search/groups_4.js | 8 + docs/NN/html/search/groups_5.html | 26 + docs/NN/html/search/groups_5.js | 4 + docs/NN/html/search/mag_sel.png | Bin 0 -> 563 bytes docs/NN/html/search/namespaces_0.html | 26 + docs/NN/html/search/namespaces_0.js | 4 + docs/NN/html/search/nomatches.html | 12 + docs/NN/html/search/pages_0.html | 26 + docs/NN/html/search/pages_0.js | 4 + docs/NN/html/search/pages_1.html | 26 + docs/NN/html/search/pages_1.js | 4 + docs/NN/html/search/search.css | 240 +++ docs/NN/html/search/search.js | 813 +++++++++ docs/NN/html/search/search_l.png | Bin 0 -> 604 bytes docs/NN/html/search/search_m.png | Bin 0 -> 158 bytes docs/NN/html/search/search_r.png | Bin 0 -> 612 bytes docs/NN/html/search/variables_0.html | 26 + docs/NN/html/search/variables_0.js | 4 + docs/NN/html/search/variables_1.html | 26 + docs/NN/html/search/variables_1.js | 10 + docs/NN/html/search/variables_2.html | 26 + docs/NN/html/search/variables_2.js | 9 + docs/NN/html/search/variables_3.html | 26 + docs/NN/html/search/variables_3.js | 8 + docs/NN/html/search/variables_4.html | 26 + docs/NN/html/search/variables_4.js | 4 + docs/NN/html/search/variables_5.html | 26 + docs/NN/html/search/variables_5.js | 5 + docs/NN/html/search/variables_6.html | 26 + docs/NN/html/search/variables_6.js | 8 + docs/NN/html/search/variables_7.html | 26 + docs/NN/html/search/variables_7.js | 8 + docs/NN/html/search/variables_8.html | 26 + docs/NN/html/search/variables_8.js | 10 + docs/NN/html/search/variables_9.html | 26 + docs/NN/html/search/variables_9.js | 7 + docs/NN/html/search/variables_a.html | 26 + docs/NN/html/search/variables_a.js | 4 + docs/NN/html/search/variables_b.html | 26 + docs/NN/html/search/variables_b.js | 5 + docs/NN/html/sync_off.png | Bin 0 -> 853 bytes docs/NN/html/sync_on.png | Bin 0 -> 845 bytes docs/NN/html/tab_a.png | Bin 0 -> 142 bytes docs/NN/html/tab_b.png | Bin 0 -> 169 bytes docs/NN/html/tab_h.png | Bin 0 -> 177 bytes docs/NN/html/tab_s.png | Bin 0 -> 184 bytes docs/NN/html/tab_topnav.png | Bin 0 -> 232 bytes docs/NN/html/tabs.css | 71 + docs/NN/html/unionarm__nnword.html | 196 +++ docs/NN/html/unionarm__nnword.js | 6 + 271 files changed, 26430 insertions(+) create mode 100644 docs/NN/html/CIFAR10_CNN.gif create mode 100644 docs/NN/html/CMSIS-NN-OVERVIEW.PNG create mode 100644 docs/NN/html/CMSIS_Logo_Final.png create mode 100644 docs/NN/html/ChangeLog_pg.html create mode 100644 docs/NN/html/GRU.gif create mode 100644 docs/NN/html/annotated.html create mode 100644 docs/NN/html/annotated.js create mode 100644 docs/NN/html/arm__convolve__1x1__HWC__q7__fast__nonsquare_8c.html create mode 100644 docs/NN/html/arm__convolve__HWC__q15__basic_8c.html create mode 100644 docs/NN/html/arm__convolve__HWC__q15__fast_8c.html create mode 100644 docs/NN/html/arm__convolve__HWC__q15__fast__nonsquare_8c.html create mode 100644 docs/NN/html/arm__convolve__HWC__q7__RGB_8c.html create mode 100644 docs/NN/html/arm__convolve__HWC__q7__basic_8c.html create mode 100644 docs/NN/html/arm__convolve__HWC__q7__basic__nonsquare_8c.html create mode 100644 docs/NN/html/arm__convolve__HWC__q7__fast_8c.html create mode 100644 docs/NN/html/arm__convolve__HWC__q7__fast__nonsquare_8c.html create mode 100644 docs/NN/html/arm__depthwise__separable__conv__HWC__q7_8c.html create mode 100644 docs/NN/html/arm__depthwise__separable__conv__HWC__q7__nonsquare_8c.html create mode 100644 docs/NN/html/arm__fully__connected__mat__q7__vec__q15_8c.html create mode 100644 docs/NN/html/arm__fully__connected__mat__q7__vec__q15__opt_8c.html create mode 100644 docs/NN/html/arm__fully__connected__q15_8c.html create mode 100644 docs/NN/html/arm__fully__connected__q15__opt_8c.html create mode 100644 docs/NN/html/arm__fully__connected__q7_8c.html create mode 100644 docs/NN/html/arm__fully__connected__q7__opt_8c.html create mode 100644 docs/NN/html/arm__nn__activations__q15_8c.html create mode 100644 docs/NN/html/arm__nn__activations__q7_8c.html create mode 100644 docs/NN/html/arm__nn__mat__mult__kernel__q7__q15_8c.html create mode 100644 docs/NN/html/arm__nn__mat__mult__kernel__q7__q15__reordered_8c.html create mode 100644 docs/NN/html/arm__nn__mult__q15_8c.html create mode 100644 docs/NN/html/arm__nn__mult__q7_8c.html create mode 100644 docs/NN/html/arm__nn__tables_8h.html create mode 100644 docs/NN/html/arm__nnexamples__cifar10_8cpp.html create mode 100644 docs/NN/html/arm__nnexamples__cifar10__inputs_8h.html create mode 100644 docs/NN/html/arm__nnexamples__cifar10__parameter_8h.html create mode 100644 docs/NN/html/arm__nnexamples__cifar10__weights_8h.html create mode 100644 docs/NN/html/arm__nnexamples__gru_8cpp.html create mode 100644 docs/NN/html/arm__nnexamples__gru__test__data_8h.html create mode 100644 docs/NN/html/arm__nnfunctions_8h.html create mode 100644 docs/NN/html/arm__nnsupportfunctions_8h.html create mode 100644 docs/NN/html/arm__nntables_8c.html create mode 100644 docs/NN/html/arm__pool__q7__HWC_8c.html create mode 100644 docs/NN/html/arm__q7__to__q15__no__shift_8c.html create mode 100644 docs/NN/html/arm__q7__to__q15__reordered__no__shift_8c.html create mode 100644 docs/NN/html/arm__relu__q15_8c.html create mode 100644 docs/NN/html/arm__relu__q7_8c.html create mode 100644 docs/NN/html/arm__softmax__q15_8c.html create mode 100644 docs/NN/html/arm__softmax__q7_8c.html create mode 100644 docs/NN/html/bc_s.png create mode 100644 docs/NN/html/bdwn.png create mode 100644 docs/NN/html/cifar10_2readme_8txt.html create mode 100644 docs/NN/html/classes.html create mode 100644 docs/NN/html/closed.png create mode 100644 docs/NN/html/cmsis.css create mode 100644 docs/NN/html/dir_06560e3359c5da94845158f0031c08e8.html create mode 100644 docs/NN/html/dir_13dc9928808d08450b31fdaf572dfc8e.html create mode 100644 docs/NN/html/dir_17aeddf785065efc95337b880bac512b.html create mode 100644 docs/NN/html/dir_1c6ec18b156ae6affcf9513e9ed30cbf.html create mode 100644 docs/NN/html/dir_21d6d99be497a80d1e903a1ff5a6bb5a.html create mode 100644 docs/NN/html/dir_42ee8ba91ca7a55df66538ce31ddec49.html create mode 100644 docs/NN/html/dir_44941783335eeef51fdbcde02b124fbf.html create mode 100644 docs/NN/html/dir_4ad8c19a899a351ef23a1c3a29886c7d.html create mode 100644 docs/NN/html/dir_5c060210645429de182d0ec8a79ad82d.html create mode 100644 docs/NN/html/dir_6d5f4079ba9c4513aa4d8d5ca02967b4.html create mode 100644 docs/NN/html/dir_8e33b5b68f9112312341506c184d7434.html create mode 100644 docs/NN/html/dir_8ff992d4a3d8f0c2e6b3f2d3952b972b.html create mode 100644 docs/NN/html/dir_a3a0a3f0894883b6608166441e8c3ad3.html create mode 100644 docs/NN/html/dir_b7d5e60e0ec4c139f7aa9a155c284f70.html create mode 100644 docs/NN/html/doxygen.css create mode 100644 docs/NN/html/doxygen.png create mode 100644 docs/NN/html/dynsections.js create mode 100644 docs/NN/html/files.html create mode 100644 docs/NN/html/ftv2blank.png create mode 100644 docs/NN/html/ftv2cl.png create mode 100644 docs/NN/html/ftv2doc.png create mode 100644 docs/NN/html/ftv2folderclosed.png create mode 100644 docs/NN/html/ftv2folderopen.png create mode 100644 docs/NN/html/ftv2lastnode.png create mode 100644 docs/NN/html/ftv2link.png create mode 100644 docs/NN/html/ftv2mlastnode.png create mode 100644 docs/NN/html/ftv2mnode.png create mode 100644 docs/NN/html/ftv2mo.png create mode 100644 docs/NN/html/ftv2node.png create mode 100644 docs/NN/html/ftv2ns.png create mode 100644 docs/NN/html/ftv2plastnode.png create mode 100644 docs/NN/html/ftv2pnode.png create mode 100644 docs/NN/html/ftv2splitbar.png create mode 100644 docs/NN/html/ftv2vertline.png create mode 100644 docs/NN/html/functions.html create mode 100644 docs/NN/html/functions_vars.html create mode 100644 docs/NN/html/globals.html create mode 100644 docs/NN/html/globals_defs.html create mode 100644 docs/NN/html/globals_enum.html create mode 100644 docs/NN/html/globals_eval.html create mode 100644 docs/NN/html/globals_func.html create mode 100644 docs/NN/html/globals_vars.html create mode 100644 docs/NN/html/group__Acti.html create mode 100644 docs/NN/html/group__Acti.js create mode 100644 docs/NN/html/group__CNNExample.html create mode 100644 docs/NN/html/group__FC.html create mode 100644 docs/NN/html/group__FC.js create mode 100644 docs/NN/html/group__GRUExample.html create mode 100644 docs/NN/html/group__NNBasicMath.html create mode 100644 docs/NN/html/group__NNBasicMath.js create mode 100644 docs/NN/html/group__NNConv.html create mode 100644 docs/NN/html/group__NNConv.js create mode 100644 docs/NN/html/group__Pooling.html create mode 100644 docs/NN/html/group__Pooling.js create mode 100644 docs/NN/html/group__Softmax.html create mode 100644 docs/NN/html/group__Softmax.js create mode 100644 docs/NN/html/group__groupNN.html create mode 100644 docs/NN/html/group__groupNN.js create mode 100644 docs/NN/html/group__nndata__convert.html create mode 100644 docs/NN/html/group__nndata__convert.js create mode 100644 docs/NN/html/gru_2readme_8txt.html create mode 100644 docs/NN/html/history_8txt.html create mode 100644 docs/NN/html/index.html create mode 100644 docs/NN/html/jquery.js create mode 100644 docs/NN/html/modules.html create mode 100644 docs/NN/html/modules.js create mode 100644 docs/NN/html/namespacemembers.html create mode 100644 docs/NN/html/namespacemembers_func.html create mode 100644 docs/NN/html/namespacemembers_vars.html create mode 100644 docs/NN/html/namespacepara__gen.html create mode 100644 docs/NN/html/namespaces.html create mode 100644 docs/NN/html/nav_f.png create mode 100644 docs/NN/html/nav_g.png create mode 100644 docs/NN/html/nav_h.png create mode 100644 docs/NN/html/navtree.css create mode 100644 docs/NN/html/navtree.js create mode 100644 docs/NN/html/navtreeindex0.js create mode 100644 docs/NN/html/open.png create mode 100644 docs/NN/html/pages.html create mode 100644 docs/NN/html/para__gen_8py.html create mode 100644 docs/NN/html/printComponentTabs.js create mode 100644 docs/NN/html/resize.js create mode 100644 docs/NN/html/search/all_0.html create mode 100644 docs/NN/html/search/all_0.js create mode 100644 docs/NN/html/search/all_1.html create mode 100644 docs/NN/html/search/all_1.js create mode 100644 docs/NN/html/search/all_10.html create mode 100644 docs/NN/html/search/all_10.js create mode 100644 docs/NN/html/search/all_11.html create mode 100644 docs/NN/html/search/all_11.js create mode 100644 docs/NN/html/search/all_2.html create mode 100644 docs/NN/html/search/all_2.js create mode 100644 docs/NN/html/search/all_3.html create mode 100644 docs/NN/html/search/all_3.js create mode 100644 docs/NN/html/search/all_4.html create mode 100644 docs/NN/html/search/all_4.js create mode 100644 docs/NN/html/search/all_5.html create mode 100644 docs/NN/html/search/all_5.js create mode 100644 docs/NN/html/search/all_6.html create mode 100644 docs/NN/html/search/all_6.js create mode 100644 docs/NN/html/search/all_7.html create mode 100644 docs/NN/html/search/all_7.js create mode 100644 docs/NN/html/search/all_8.html create mode 100644 docs/NN/html/search/all_8.js create mode 100644 docs/NN/html/search/all_9.html create mode 100644 docs/NN/html/search/all_9.js create mode 100644 docs/NN/html/search/all_a.html create mode 100644 docs/NN/html/search/all_a.js create mode 100644 docs/NN/html/search/all_b.html create mode 100644 docs/NN/html/search/all_b.js create mode 100644 docs/NN/html/search/all_c.html create mode 100644 docs/NN/html/search/all_c.js create mode 100644 docs/NN/html/search/all_d.html create mode 100644 docs/NN/html/search/all_d.js create mode 100644 docs/NN/html/search/all_e.html create mode 100644 docs/NN/html/search/all_e.js create mode 100644 docs/NN/html/search/all_f.html create mode 100644 docs/NN/html/search/all_f.js create mode 100644 docs/NN/html/search/classes_0.html create mode 100644 docs/NN/html/search/classes_0.js create mode 100644 docs/NN/html/search/close.png create mode 100644 docs/NN/html/search/defines_0.html create mode 100644 docs/NN/html/search/defines_0.js create mode 100644 docs/NN/html/search/defines_1.html create mode 100644 docs/NN/html/search/defines_1.js create mode 100644 docs/NN/html/search/defines_2.html create mode 100644 docs/NN/html/search/defines_2.js create mode 100644 docs/NN/html/search/defines_3.html create mode 100644 docs/NN/html/search/defines_3.js create mode 100644 docs/NN/html/search/defines_4.html create mode 100644 docs/NN/html/search/defines_4.js create mode 100644 docs/NN/html/search/defines_5.html create mode 100644 docs/NN/html/search/defines_5.js create mode 100644 docs/NN/html/search/defines_6.html create mode 100644 docs/NN/html/search/defines_6.js create mode 100644 docs/NN/html/search/defines_7.html create mode 100644 docs/NN/html/search/defines_7.js create mode 100644 docs/NN/html/search/enums_0.html create mode 100644 docs/NN/html/search/enums_0.js create mode 100644 docs/NN/html/search/enumvalues_0.html create mode 100644 docs/NN/html/search/enumvalues_0.js create mode 100644 docs/NN/html/search/files_0.html create mode 100644 docs/NN/html/search/files_0.js create mode 100644 docs/NN/html/search/files_1.html create mode 100644 docs/NN/html/search/files_1.js create mode 100644 docs/NN/html/search/files_2.html create mode 100644 docs/NN/html/search/files_2.js create mode 100644 docs/NN/html/search/files_3.html create mode 100644 docs/NN/html/search/files_3.js create mode 100644 docs/NN/html/search/files_4.html create mode 100644 docs/NN/html/search/files_4.js create mode 100644 docs/NN/html/search/functions_0.html create mode 100644 docs/NN/html/search/functions_0.js create mode 100644 docs/NN/html/search/functions_1.html create mode 100644 docs/NN/html/search/functions_1.js create mode 100644 docs/NN/html/search/functions_2.html create mode 100644 docs/NN/html/search/functions_2.js create mode 100644 docs/NN/html/search/functions_3.html create mode 100644 docs/NN/html/search/functions_3.js create mode 100644 docs/NN/html/search/groups_0.html create mode 100644 docs/NN/html/search/groups_0.js create mode 100644 docs/NN/html/search/groups_1.html create mode 100644 docs/NN/html/search/groups_1.js create mode 100644 docs/NN/html/search/groups_2.html create mode 100644 docs/NN/html/search/groups_2.js create mode 100644 docs/NN/html/search/groups_3.html create mode 100644 docs/NN/html/search/groups_3.js create mode 100644 docs/NN/html/search/groups_4.html create mode 100644 docs/NN/html/search/groups_4.js create mode 100644 docs/NN/html/search/groups_5.html create mode 100644 docs/NN/html/search/groups_5.js create mode 100644 docs/NN/html/search/mag_sel.png create mode 100644 docs/NN/html/search/namespaces_0.html create mode 100644 docs/NN/html/search/namespaces_0.js create mode 100644 docs/NN/html/search/nomatches.html create mode 100644 docs/NN/html/search/pages_0.html create mode 100644 docs/NN/html/search/pages_0.js create mode 100644 docs/NN/html/search/pages_1.html create mode 100644 docs/NN/html/search/pages_1.js create mode 100644 docs/NN/html/search/search.css create mode 100644 docs/NN/html/search/search.js create mode 100644 docs/NN/html/search/search_l.png create mode 100644 docs/NN/html/search/search_m.png create mode 100644 docs/NN/html/search/search_r.png create mode 100644 docs/NN/html/search/variables_0.html create mode 100644 docs/NN/html/search/variables_0.js create mode 100644 docs/NN/html/search/variables_1.html create mode 100644 docs/NN/html/search/variables_1.js create mode 100644 docs/NN/html/search/variables_2.html create mode 100644 docs/NN/html/search/variables_2.js create mode 100644 docs/NN/html/search/variables_3.html create mode 100644 docs/NN/html/search/variables_3.js create mode 100644 docs/NN/html/search/variables_4.html create mode 100644 docs/NN/html/search/variables_4.js create mode 100644 docs/NN/html/search/variables_5.html create mode 100644 docs/NN/html/search/variables_5.js create mode 100644 docs/NN/html/search/variables_6.html create mode 100644 docs/NN/html/search/variables_6.js create mode 100644 docs/NN/html/search/variables_7.html create mode 100644 docs/NN/html/search/variables_7.js create mode 100644 docs/NN/html/search/variables_8.html create mode 100644 docs/NN/html/search/variables_8.js create mode 100644 docs/NN/html/search/variables_9.html create mode 100644 docs/NN/html/search/variables_9.js create mode 100644 docs/NN/html/search/variables_a.html create mode 100644 docs/NN/html/search/variables_a.js create mode 100644 docs/NN/html/search/variables_b.html create mode 100644 docs/NN/html/search/variables_b.js create mode 100644 docs/NN/html/sync_off.png create mode 100644 docs/NN/html/sync_on.png create mode 100644 docs/NN/html/tab_a.png create mode 100644 docs/NN/html/tab_b.png create mode 100644 docs/NN/html/tab_h.png create mode 100644 docs/NN/html/tab_s.png create mode 100644 docs/NN/html/tab_topnav.png create mode 100644 docs/NN/html/tabs.css create mode 100644 docs/NN/html/unionarm__nnword.html create mode 100644 docs/NN/html/unionarm__nnword.js (limited to 'docs/NN/html') diff --git a/docs/NN/html/CIFAR10_CNN.gif b/docs/NN/html/CIFAR10_CNN.gif new file mode 100644 index 0000000..410114f Binary files /dev/null and b/docs/NN/html/CIFAR10_CNN.gif differ diff --git a/docs/NN/html/CMSIS-NN-OVERVIEW.PNG b/docs/NN/html/CMSIS-NN-OVERVIEW.PNG new file mode 100644 index 0000000..83545cb Binary files /dev/null and b/docs/NN/html/CMSIS-NN-OVERVIEW.PNG differ diff --git a/docs/NN/html/CMSIS_Logo_Final.png b/docs/NN/html/CMSIS_Logo_Final.png new file mode 100644 index 0000000..2056b7e Binary files /dev/null and b/docs/NN/html/CMSIS_Logo_Final.png differ diff --git a/docs/NN/html/ChangeLog_pg.html b/docs/NN/html/ChangeLog_pg.html new file mode 100644 index 0000000..f04ca5c --- /dev/null +++ b/docs/NN/html/ChangeLog_pg.html @@ -0,0 +1,147 @@ + + + + + +Revision History of CMSIS-NN +CMSIS-NN: Revision History of CMSIS-NN + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Revision History of CMSIS-NN
+
+
+
+ + + + + + +
Version Description
V1.1.0 Added new math functions:
+
    +
  • +arm_convolve_HWC_q7_basic_nonsquare
  • +
  • +arm_convolve_HWC_q15_fast_nonsquare
  • +
  • +arm_nn_mult_q7
  • +
  • +arm_nn_mult_q15
  • +
+Fixed minor issues.
V1.0.0 Initial version
+
+
+ + + + diff --git a/docs/NN/html/GRU.gif b/docs/NN/html/GRU.gif new file mode 100644 index 0000000..c5cfb4f Binary files /dev/null and b/docs/NN/html/GRU.gif differ diff --git a/docs/NN/html/annotated.html b/docs/NN/html/annotated.html new file mode 100644 index 0000000..8b661da --- /dev/null +++ b/docs/NN/html/annotated.html @@ -0,0 +1,140 @@ + + + + + +Data Structures +CMSIS-NN: Data Structures + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Data Structures
+
+
+
Here are the data structures with brief descriptions:
+ + + +
oNpara_gen
\Carm_nnwordUnion for SIMD access of Q31/Q15/Q7 types
+
+
+
+ + + + diff --git a/docs/NN/html/annotated.js b/docs/NN/html/annotated.js new file mode 100644 index 0000000..4f4e45b --- /dev/null +++ b/docs/NN/html/annotated.js @@ -0,0 +1,5 @@ +var annotated = +[ + [ "para_gen", "namespacepara__gen.html", null ], + [ "arm_nnword", "unionarm__nnword.html", "unionarm__nnword" ] +]; \ No newline at end of file diff --git a/docs/NN/html/arm__convolve__1x1__HWC__q7__fast__nonsquare_8c.html b/docs/NN/html/arm__convolve__1x1__HWC__q7__fast__nonsquare_8c.html new file mode 100644 index 0000000..dfb17bc --- /dev/null +++ b/docs/NN/html/arm__convolve__1x1__HWC__q7__fast__nonsquare_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_1x1_HWC_q7_fast_nonsquare.c File Reference +CMSIS-NN: arm_convolve_1x1_HWC_q7_fast_nonsquare.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_1x1_HWC_q7_fast_nonsquare.c File Reference
+
+
+ + + + + +

+Functions

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)
 Fast Q7 version of 1x1 convolution (non-sqaure shape) More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__convolve__HWC__q15__basic_8c.html b/docs/NN/html/arm__convolve__HWC__q15__basic_8c.html new file mode 100644 index 0000000..3cbdafb --- /dev/null +++ b/docs/NN/html/arm__convolve__HWC__q15__basic_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_HWC_q15_basic.c File Reference +CMSIS-NN: arm_convolve_HWC_q15_basic.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_HWC_q15_basic.c File Reference
+
+
+ + + + + +

+Functions

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)
 Basic Q15 convolution function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__convolve__HWC__q15__fast_8c.html b/docs/NN/html/arm__convolve__HWC__q15__fast_8c.html new file mode 100644 index 0000000..e277767 --- /dev/null +++ b/docs/NN/html/arm__convolve__HWC__q15__fast_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_HWC_q15_fast.c File Reference +CMSIS-NN: arm_convolve_HWC_q15_fast.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_HWC_q15_fast.c File Reference
+
+
+ + + + + +

+Functions

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)
 Fast Q15 convolution function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__convolve__HWC__q15__fast__nonsquare_8c.html b/docs/NN/html/arm__convolve__HWC__q15__fast__nonsquare_8c.html new file mode 100644 index 0000000..fd082ac --- /dev/null +++ b/docs/NN/html/arm__convolve__HWC__q15__fast__nonsquare_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_HWC_q15_fast_nonsquare.c File Reference +CMSIS-NN: arm_convolve_HWC_q15_fast_nonsquare.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_HWC_q15_fast_nonsquare.c File Reference
+
+
+ + + + + +

+Functions

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)
 Fast Q15 convolution function (non-sqaure shape) More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__convolve__HWC__q7__RGB_8c.html b/docs/NN/html/arm__convolve__HWC__q7__RGB_8c.html new file mode 100644 index 0000000..dbf4deb --- /dev/null +++ b/docs/NN/html/arm__convolve__HWC__q7__RGB_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_HWC_q7_RGB.c File Reference +CMSIS-NN: arm_convolve_HWC_q7_RGB.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_HWC_q7_RGB.c File Reference
+
+
+ + + + + +

+Functions

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)
 Q7 convolution function for RGB image. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__convolve__HWC__q7__basic_8c.html b/docs/NN/html/arm__convolve__HWC__q7__basic_8c.html new file mode 100644 index 0000000..97e8ee5 --- /dev/null +++ b/docs/NN/html/arm__convolve__HWC__q7__basic_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_HWC_q7_basic.c File Reference +CMSIS-NN: arm_convolve_HWC_q7_basic.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_HWC_q7_basic.c File Reference
+
+
+ + + + + +

+Functions

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)
 Basic Q7 convolution function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__convolve__HWC__q7__basic__nonsquare_8c.html b/docs/NN/html/arm__convolve__HWC__q7__basic__nonsquare_8c.html new file mode 100644 index 0000000..7c34137 --- /dev/null +++ b/docs/NN/html/arm__convolve__HWC__q7__basic__nonsquare_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_HWC_q7_basic_nonsquare.c File Reference +CMSIS-NN: arm_convolve_HWC_q7_basic_nonsquare.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_HWC_q7_basic_nonsquare.c File Reference
+
+
+ + + + + +

+Functions

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)
 Basic Q7 convolution function (non-sqaure shape) More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__convolve__HWC__q7__fast_8c.html b/docs/NN/html/arm__convolve__HWC__q7__fast_8c.html new file mode 100644 index 0000000..adefce2 --- /dev/null +++ b/docs/NN/html/arm__convolve__HWC__q7__fast_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_HWC_q7_fast.c File Reference +CMSIS-NN: arm_convolve_HWC_q7_fast.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_HWC_q7_fast.c File Reference
+
+
+ + + + + +

+Functions

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)
 Fast Q7 convolution function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__convolve__HWC__q7__fast__nonsquare_8c.html b/docs/NN/html/arm__convolve__HWC__q7__fast__nonsquare_8c.html new file mode 100644 index 0000000..36cd305 --- /dev/null +++ b/docs/NN/html/arm__convolve__HWC__q7__fast__nonsquare_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_convolve_HWC_q7_fast_nonsquare.c File Reference +CMSIS-NN: arm_convolve_HWC_q7_fast_nonsquare.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_convolve_HWC_q7_fast_nonsquare.c File Reference
+
+
+ + + + + +

+Functions

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)
 Fast Q7 convolution function (non-sqaure shape) More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__depthwise__separable__conv__HWC__q7_8c.html b/docs/NN/html/arm__depthwise__separable__conv__HWC__q7_8c.html new file mode 100644 index 0000000..2637d6d --- /dev/null +++ b/docs/NN/html/arm__depthwise__separable__conv__HWC__q7_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_depthwise_separable_conv_HWC_q7.c File Reference +CMSIS-NN: arm_depthwise_separable_conv_HWC_q7.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_depthwise_separable_conv_HWC_q7.c File Reference
+
+
+ + + + + +

+Functions

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)
 Q7 depthwise separable convolution function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__depthwise__separable__conv__HWC__q7__nonsquare_8c.html b/docs/NN/html/arm__depthwise__separable__conv__HWC__q7__nonsquare_8c.html new file mode 100644 index 0000000..4062ee9 --- /dev/null +++ b/docs/NN/html/arm__depthwise__separable__conv__HWC__q7__nonsquare_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_depthwise_separable_conv_HWC_q7_nonsquare.c File Reference +CMSIS-NN: arm_depthwise_separable_conv_HWC_q7_nonsquare.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_depthwise_separable_conv_HWC_q7_nonsquare.c File Reference
+
+
+ + + + + +

+Functions

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)
 Q7 depthwise separable convolution function (non-square shape) More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__fully__connected__mat__q7__vec__q15_8c.html b/docs/NN/html/arm__fully__connected__mat__q7__vec__q15_8c.html new file mode 100644 index 0000000..3f2044f --- /dev/null +++ b/docs/NN/html/arm__fully__connected__mat__q7__vec__q15_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_fully_connected_mat_q7_vec_q15.c File Reference +CMSIS-NN: arm_fully_connected_mat_q7_vec_q15.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_fully_connected_mat_q7_vec_q15.c File Reference
+
+
+ + + + + +

+Functions

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)
 Mixed Q15-Q7 fully-connected layer function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__fully__connected__mat__q7__vec__q15__opt_8c.html b/docs/NN/html/arm__fully__connected__mat__q7__vec__q15__opt_8c.html new file mode 100644 index 0000000..627a1fd --- /dev/null +++ b/docs/NN/html/arm__fully__connected__mat__q7__vec__q15__opt_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_fully_connected_mat_q7_vec_q15_opt.c File Reference +CMSIS-NN: arm_fully_connected_mat_q7_vec_q15_opt.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_fully_connected_mat_q7_vec_q15_opt.c File Reference
+
+
+ + + + + +

+Functions

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)
 Mixed Q15-Q7 opt fully-connected layer function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__fully__connected__q15_8c.html b/docs/NN/html/arm__fully__connected__q15_8c.html new file mode 100644 index 0000000..faef3c8 --- /dev/null +++ b/docs/NN/html/arm__fully__connected__q15_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_fully_connected_q15.c File Reference +CMSIS-NN: arm_fully_connected_q15.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_fully_connected_q15.c File Reference
+
+
+ + + + + +

+Functions

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)
 Q15 opt fully-connected layer function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__fully__connected__q15__opt_8c.html b/docs/NN/html/arm__fully__connected__q15__opt_8c.html new file mode 100644 index 0000000..b7787ce --- /dev/null +++ b/docs/NN/html/arm__fully__connected__q15__opt_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_fully_connected_q15_opt.c File Reference +CMSIS-NN: arm_fully_connected_q15_opt.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_fully_connected_q15_opt.c File Reference
+
+
+ + + + + +

+Functions

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)
 Q15 opt fully-connected layer function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__fully__connected__q7_8c.html b/docs/NN/html/arm__fully__connected__q7_8c.html new file mode 100644 index 0000000..7f16d98 --- /dev/null +++ b/docs/NN/html/arm__fully__connected__q7_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_fully_connected_q7.c File Reference +CMSIS-NN: arm_fully_connected_q7.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_fully_connected_q7.c File Reference
+
+
+ + + + + +

+Functions

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)
 Q7 basic fully-connected layer function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__fully__connected__q7__opt_8c.html b/docs/NN/html/arm__fully__connected__q7__opt_8c.html new file mode 100644 index 0000000..00fae7d --- /dev/null +++ b/docs/NN/html/arm__fully__connected__q7__opt_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_fully_connected_q7_opt.c File Reference +CMSIS-NN: arm_fully_connected_q7_opt.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_fully_connected_q7_opt.c File Reference
+
+
+ + + + + +

+Functions

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)
 Q7 opt fully-connected layer function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__nn__activations__q15_8c.html b/docs/NN/html/arm__nn__activations__q15_8c.html new file mode 100644 index 0000000..9c44ff1 --- /dev/null +++ b/docs/NN/html/arm__nn__activations__q15_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_nn_activations_q15.c File Reference +CMSIS-NN: arm_nn_activations_q15.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nn_activations_q15.c File Reference
+
+
+ + + + + +

+Functions

void arm_nn_activations_direct_q15 (q15_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type)
 Q15 neural network activation function using direct table look-up. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__nn__activations__q7_8c.html b/docs/NN/html/arm__nn__activations__q7_8c.html new file mode 100644 index 0000000..90dab8e --- /dev/null +++ b/docs/NN/html/arm__nn__activations__q7_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_nn_activations_q7.c File Reference +CMSIS-NN: arm_nn_activations_q7.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nn_activations_q7.c File Reference
+
+
+ + + + + +

+Functions

void arm_nn_activations_direct_q7 (q7_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type)
 Q7 neural network activation function using direct table look-up. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__nn__mat__mult__kernel__q7__q15_8c.html b/docs/NN/html/arm__nn__mat__mult__kernel__q7__q15_8c.html new file mode 100644 index 0000000..1b32c5a --- /dev/null +++ b/docs/NN/html/arm__nn__mat__mult__kernel__q7__q15_8c.html @@ -0,0 +1,221 @@ + + + + + +arm_nn_mat_mult_kernel_q7_q15.c File Reference +CMSIS-NN: arm_nn_mat_mult_kernel_q7_q15.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nn_mat_mult_kernel_q7_q15.c File Reference
+
+
+ + + + + +

+Functions

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)
 Matrix-multiplication function for convolution. More...
 
+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+

Matrix-Multiplication Kernels for Convolution.

+
Parameters
+ + + + + + + + + +
[in]pApointer to operand A
[in]pInBufferpointer to operand B, always conssists of 2 vectors
[in]ch_im_outnumRow of A
[in]numCol_AnumCol of A
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biasthe bias
[in,out]pOutpointer to output
+
+
+
Returns
The function returns the incremented output pointer
+

This function does the matrix multiplication with weight matrix and 2 columns from im2col.

+ +

References NN_ROUND.

+ +

Referenced by arm_convolve_HWC_q7_basic(), arm_convolve_HWC_q7_basic_nonsquare(), and arm_convolve_HWC_q7_RGB().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nn__mat__mult__kernel__q7__q15__reordered_8c.html b/docs/NN/html/arm__nn__mat__mult__kernel__q7__q15__reordered_8c.html new file mode 100644 index 0000000..2fee232 --- /dev/null +++ b/docs/NN/html/arm__nn__mat__mult__kernel__q7__q15__reordered_8c.html @@ -0,0 +1,220 @@ + + + + + +arm_nn_mat_mult_kernel_q7_q15_reordered.c File Reference +CMSIS-NN: arm_nn_mat_mult_kernel_q7_q15_reordered.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nn_mat_mult_kernel_q7_q15_reordered.c File Reference
+
+
+ + + + + +

+Functions

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)
 Matrix-multiplication function for convolution with reordered columns. More...
 
+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + +
[in]pApointer to operand A
[in]pInBufferpointer to operand B, always conssists of 2 vectors
[in]ch_im_outnumRow of A
[in]numCol_AnumCol of A
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biasthe bias
[in,out]pOutpointer to output
+
+
+
Returns
The function returns the incremented output pointer
+

This function assumes that data in pInBuffer are reordered

+ +

References NN_ROUND.

+ +

Referenced by arm_convolve_1x1_HWC_q7_fast_nonsquare(), arm_convolve_HWC_q7_fast(), and arm_convolve_HWC_q7_fast_nonsquare().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nn__mult__q15_8c.html b/docs/NN/html/arm__nn__mult__q15_8c.html new file mode 100644 index 0000000..0b64078 --- /dev/null +++ b/docs/NN/html/arm__nn__mult__q15_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_nn_mult_q15.c File Reference +CMSIS-NN: arm_nn_mult_q15.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nn_mult_q15.c File Reference
+
+
+ + + + + +

+Functions

void arm_nn_mult_q15 (q15_t *pSrcA, q15_t *pSrcB, q15_t *pDst, const uint16_t out_shift, uint32_t blockSize)
 Q7 vector multiplication with variable output shifts. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__nn__mult__q7_8c.html b/docs/NN/html/arm__nn__mult__q7_8c.html new file mode 100644 index 0000000..6834f95 --- /dev/null +++ b/docs/NN/html/arm__nn__mult__q7_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_nn_mult_q7.c File Reference +CMSIS-NN: arm_nn_mult_q7.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nn_mult_q7.c File Reference
+
+
+ + + + + +

+Functions

void arm_nn_mult_q7 (q7_t *pSrcA, q7_t *pSrcB, q7_t *pDst, const uint16_t out_shift, uint32_t blockSize)
 Q7 vector multiplication with variable output shifts. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__nn__tables_8h.html b/docs/NN/html/arm__nn__tables_8h.html new file mode 100644 index 0000000..84dd3f8 --- /dev/null +++ b/docs/NN/html/arm__nn__tables_8h.html @@ -0,0 +1,240 @@ + + + + + +arm_nn_tables.h File Reference +CMSIS-NN: arm_nn_tables.h File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nn_tables.h File Reference
+
+
+ + + + + + + + + + + + + + + + + +

+Variables

const q15_t sigmoidTable_q15 [256]
 tables for various activation functions More...
 
const q7_t sigmoidTable_q7 [256]
 tables for various activation functions More...
 
const q7_t tanhTable_q7 [256]
 
const q15_t tanhTable_q15 [256]
 
const q15_t sigmoidHTable_q15 [192]
 2-way tables for various activation functions More...
 
const q15_t sigmoidLTable_q15 [128]
 
+

Variable Documentation

+ +
+
+ + + + +
const q15_t sigmoidHTable_q15
+
+

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

+ +
+
+ +
+
+ + + + +
const q15_t sigmoidLTable_q15
+
+ +
+
+ +
+
+ + + + +
const q15_t sigmoidTable_q15[256]
+
+ +

Referenced by arm_nn_activations_direct_q15().

+ +
+
+ +
+
+ + + + +
const q7_t sigmoidTable_q7[256]
+
+

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

+ +

Referenced by arm_nn_activations_direct_q7().

+ +
+
+ +
+
+ + + + +
const q15_t tanhTable_q15[256]
+
+ +

Referenced by arm_nn_activations_direct_q15().

+ +
+
+ +
+
+ + + + +
const q7_t tanhTable_q7[256]
+
+ +

Referenced by arm_nn_activations_direct_q7().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nnexamples__cifar10_8cpp.html b/docs/NN/html/arm__nnexamples__cifar10_8cpp.html new file mode 100644 index 0000000..55779eb --- /dev/null +++ b/docs/NN/html/arm__nnexamples__cifar10_8cpp.html @@ -0,0 +1,416 @@ + + + + + +arm_nnexamples_cifar10.cpp File Reference +CMSIS-NN: arm_nnexamples_cifar10.cpp File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nnexamples_cifar10.cpp File Reference
+
+
+ + + + +

+Functions

int main ()
 
+ + + + + + + + + + + + + + + + + + + + + + + + + +

+Variables

static q7_t conv1_wt [CONV1_IM_CH *CONV1_KER_DIM *CONV1_KER_DIM *CONV1_OUT_CH]
 
static q7_t conv1_bias [CONV1_OUT_CH]
 
static q7_t conv2_wt [CONV2_IM_CH *CONV2_KER_DIM *CONV2_KER_DIM *CONV2_OUT_CH]
 
static q7_t conv2_bias [CONV2_OUT_CH]
 
static q7_t conv3_wt [CONV3_IM_CH *CONV3_KER_DIM *CONV3_KER_DIM *CONV3_OUT_CH]
 
static q7_t conv3_bias [CONV3_OUT_CH]
 
static q7_t ip1_wt [IP1_DIM *IP1_OUT]
 
static q7_t ip1_bias [IP1_OUT]
 
uint8_t image_data [CONV1_IM_CH *CONV1_IM_DIM *CONV1_IM_DIM]
 
q7_t output_data [IP1_OUT]
 
q7_t col_buffer [2 *5 *5 *32 *2]
 
q7_t scratch_buffer [32 *32 *10 *4]
 
+

Function Documentation

+ + +

Variable Documentation

+ +
+
+ + + + +
q7_t col_buffer[2 *5 *5 *32 *2]
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t conv1_bias[CONV1_OUT_CH]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t conv1_wt[CONV1_IM_CH *CONV1_KER_DIM *CONV1_KER_DIM *CONV1_OUT_CH]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t conv2_bias[CONV2_OUT_CH]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t conv2_wt[CONV2_IM_CH *CONV2_KER_DIM *CONV2_KER_DIM *CONV2_OUT_CH]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t conv3_bias[CONV3_OUT_CH]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t conv3_wt[CONV3_IM_CH *CONV3_KER_DIM *CONV3_KER_DIM *CONV3_OUT_CH]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
uint8_t image_data[CONV1_IM_CH *CONV1_IM_DIM *CONV1_IM_DIM]
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t ip1_bias[IP1_OUT]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t ip1_wt[IP1_DIM *IP1_OUT]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
q7_t output_data[IP1_OUT]
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
q7_t scratch_buffer[32 *32 *10 *4]
+
+ +

Referenced by main().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nnexamples__cifar10__inputs_8h.html b/docs/NN/html/arm__nnexamples__cifar10__inputs_8h.html new file mode 100644 index 0000000..d1861cc --- /dev/null +++ b/docs/NN/html/arm__nnexamples__cifar10__inputs_8h.html @@ -0,0 +1,150 @@ + + + + + +arm_nnexamples_cifar10_inputs.h File Reference +CMSIS-NN: arm_nnexamples_cifar10_inputs.h File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nnexamples_cifar10_inputs.h File Reference
+
+
+ + + + +

+Macros

#define IMG_DATA
 
+

Macro Definition Documentation

+ +
+
+ + + + +
#define IMG_DATA
+
+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nnexamples__cifar10__parameter_8h.html b/docs/NN/html/arm__nnexamples__cifar10__parameter_8h.html new file mode 100644 index 0000000..44a1607 --- /dev/null +++ b/docs/NN/html/arm__nnexamples__cifar10__parameter_8h.html @@ -0,0 +1,724 @@ + + + + + +arm_nnexamples_cifar10_parameter.h File Reference +CMSIS-NN: arm_nnexamples_cifar10_parameter.h File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nnexamples_cifar10_parameter.h File Reference
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

+Macros

#define CONV1_IM_DIM
 
#define CONV1_IM_CH
 
#define CONV1_KER_DIM
 
#define CONV1_PADDING
 
#define CONV1_STRIDE
 
#define CONV1_OUT_CH
 
#define CONV1_OUT_DIM
 
#define POOL1_KER_DIM
 
#define POOL1_STRIDE
 
#define POOL1_PADDING
 
#define POOL1_OUT_DIM
 
#define CONV2_IM_DIM
 
#define CONV2_IM_CH
 
#define CONV2_KER_DIM
 
#define CONV2_PADDING
 
#define CONV2_STRIDE
 
#define CONV2_OUT_CH
 
#define CONV2_OUT_DIM
 
#define POOL2_KER_DIM
 
#define POOL2_STRIDE
 
#define POOL2_PADDING
 
#define POOL2_OUT_DIM
 
#define CONV3_IM_DIM
 
#define CONV3_IM_CH
 
#define CONV3_KER_DIM
 
#define CONV3_PADDING
 
#define CONV3_STRIDE
 
#define CONV3_OUT_CH
 
#define CONV3_OUT_DIM
 
#define POOL3_KER_DIM
 
#define POOL3_STRIDE
 
#define POOL3_PADDING
 
#define POOL3_OUT_DIM
 
#define IP1_DIM
 
#define IP1_IM_DIM
 
#define IP1_IM_CH
 
#define IP1_OUT
 
+

Macro Definition Documentation

+ +
+
+ + + + +
#define CONV1_IM_CH
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV1_IM_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV1_KER_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV1_OUT_CH
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV1_OUT_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV1_PADDING
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV1_STRIDE
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_IM_CH
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_IM_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_KER_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_OUT_CH
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_OUT_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_PADDING
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_STRIDE
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_IM_CH
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_IM_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_KER_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_OUT_CH
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_OUT_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_PADDING
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_STRIDE
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define IP1_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define IP1_IM_CH
+
+ +
+
+ +
+
+ + + + +
#define IP1_IM_DIM
+
+ +
+
+ +
+
+ + + + +
#define IP1_OUT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL1_KER_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL1_OUT_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL1_PADDING
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL1_STRIDE
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL2_KER_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL2_OUT_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL2_PADDING
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL2_STRIDE
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL3_KER_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL3_OUT_DIM
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL3_PADDING
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define POOL3_STRIDE
+
+ +

Referenced by main().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nnexamples__cifar10__weights_8h.html b/docs/NN/html/arm__nnexamples__cifar10__weights_8h.html new file mode 100644 index 0000000..c37187e --- /dev/null +++ b/docs/NN/html/arm__nnexamples__cifar10__weights_8h.html @@ -0,0 +1,408 @@ + + + + + +arm_nnexamples_cifar10_weights.h File Reference +CMSIS-NN: arm_nnexamples_cifar10_weights.h File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nnexamples_cifar10_weights.h File Reference
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

+Macros

#define CONV1_WT
 
#define CONV1_BIAS
 
#define CONV2_WT
 
#define CONV2_BIAS
 
#define CONV3_WT
 
#define CONV3_BIAS
 
#define IP1_WT
 
#define IP1_BIAS
 
#define CONV1_BIAS_LSHIFT
 
#define CONV1_OUT_RSHIFT
 
#define CONV2_BIAS_LSHIFT
 
#define CONV2_OUT_RSHIFT
 
#define CONV3_BIAS_LSHIFT
 
#define CONV3_OUT_RSHIFT
 
#define IP1_BIAS_LSHIFT
 
#define IP1_OUT_RSHIFT
 
#define INPUT_MEAN_SHIFT
 
#define INPUT_RIGHT_SHIFT
 
+

Macro Definition Documentation

+ +
+
+ + + + +
#define CONV1_BIAS
+
+ +
+
+ +
+
+ + + + +
#define CONV1_BIAS_LSHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV1_OUT_RSHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV1_WT
+
+ +
+
+ +
+
+ + + + +
#define CONV2_BIAS
+
+ +
+
+ +
+
+ + + + +
#define CONV2_BIAS_LSHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_OUT_RSHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV2_WT
+
+ +
+
+ +
+
+ + + + +
#define CONV3_BIAS
+
+ +
+
+ +
+
+ + + + +
#define CONV3_BIAS_LSHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_OUT_RSHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define CONV3_WT
+
+ +
+
+ +
+
+ + + + +
#define INPUT_MEAN_SHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define INPUT_RIGHT_SHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define IP1_BIAS
+
+ +
+
+ +
+
+ + + + +
#define IP1_BIAS_LSHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define IP1_OUT_RSHIFT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define IP1_WT
+
+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nnexamples__gru_8cpp.html b/docs/NN/html/arm__nnexamples__gru_8cpp.html new file mode 100644 index 0000000..1b43700 --- /dev/null +++ b/docs/NN/html/arm__nnexamples__gru_8cpp.html @@ -0,0 +1,531 @@ + + + + + +arm_nnexamples_gru.cpp File Reference +CMSIS-NN: arm_nnexamples_gru.cpp File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nnexamples_gru.cpp File Reference
+
+
+ + + + + + + + + + +

+Macros

#define DIM_HISTORY
 
#define DIM_INPUT
 
#define DIM_VEC
 
#define USE_X4
 
+ + + + + +

+Functions

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)
 
int main ()
 
+ + + + + + + + + + + + + + + + + + + + + +

+Variables

static q7_t update_gate_weights [DIM_VEC *DIM_HISTORY]
 
static q7_t reset_gate_weights [DIM_VEC *DIM_HISTORY]
 
static q7_t hidden_state_weights [DIM_VEC *DIM_HISTORY]
 
static q7_t update_gate_bias [DIM_HISTORY]
 
static q7_t reset_gate_bias [DIM_HISTORY]
 
static q7_t hidden_state_bias [DIM_HISTORY]
 
static q15_t test_input1 [DIM_INPUT]
 
static q15_t test_input2 [DIM_INPUT]
 
static q15_t test_history [DIM_HISTORY]
 
q15_t scratch_buffer [DIM_HISTORY *4+DIM_INPUT]
 
+

Macro Definition Documentation

+ +
+
+ + + + +
#define DIM_HISTORY
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define DIM_INPUT
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
#define DIM_VEC
+
+ +
+
+ +
+
+ + + + +
#define USE_X4
+
+ +
+
+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
+ + +

Variable Documentation

+ +
+
+ + + + + +
+ + + + +
q7_t hidden_state_bias[DIM_HISTORY]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t hidden_state_weights[DIM_VEC *DIM_HISTORY]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t reset_gate_bias[DIM_HISTORY]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t reset_gate_weights[DIM_VEC *DIM_HISTORY]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + +
q15_t scratch_buffer[DIM_HISTORY *4+DIM_INPUT]
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q15_t test_history[DIM_HISTORY]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q15_t test_input1[DIM_INPUT]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q15_t test_input2[DIM_INPUT]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t update_gate_bias[DIM_HISTORY]
+
+static
+
+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + +
+ + + + +
q7_t update_gate_weights[DIM_VEC *DIM_HISTORY]
+
+static
+
+ +

Referenced by main().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nnexamples__gru__test__data_8h.html b/docs/NN/html/arm__nnexamples__gru__test__data_8h.html new file mode 100644 index 0000000..8552564 --- /dev/null +++ b/docs/NN/html/arm__nnexamples__gru__test__data_8h.html @@ -0,0 +1,304 @@ + + + + + +arm_nnexamples_gru_test_data.h File Reference +CMSIS-NN: arm_nnexamples_gru_test_data.h File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nnexamples_gru_test_data.h File Reference
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +

+Macros

#define UPDATE_GATE_WEIGHT_X2
 
#define UPDATE_GATE_WEIGHT_X4
 
#define RESET_GATE_WEIGHT_X2
 
#define RESET_GATE_WEIGHT_X4
 
#define HIDDEN_STATE_WEIGHT_X2
 
#define HIDDEN_STATE_WEIGHT_X4
 
#define UPDATE_GATE_BIAS
 
#define RESET_GATE_BIAS
 
#define HIDDEN_STATE_BIAS
 
#define INPUT_DATA1
 
#define INPUT_DATA2
 
#define HISTORY_DATA
 
+

Macro Definition Documentation

+ +
+
+ + + + +
#define HIDDEN_STATE_BIAS
+
+ +
+
+ +
+
+ + + + +
#define HIDDEN_STATE_WEIGHT_X2
+
+ +
+
+ +
+
+ + + + +
#define HIDDEN_STATE_WEIGHT_X4
+
+ +
+
+ +
+
+ + + + +
#define HISTORY_DATA
+
+ +
+
+ +
+
+ + + + +
#define INPUT_DATA1
+
+ +
+
+ +
+
+ + + + +
#define INPUT_DATA2
+
+ +
+
+ +
+
+ + + + +
#define RESET_GATE_BIAS
+
+ +
+
+ +
+
+ + + + +
#define RESET_GATE_WEIGHT_X2
+
+ +
+
+ +
+
+ + + + +
#define RESET_GATE_WEIGHT_X4
+
+ +
+
+ +
+
+ + + + +
#define UPDATE_GATE_BIAS
+
+ +
+
+ +
+
+ + + + +
#define UPDATE_GATE_WEIGHT_X2
+
+ +
+
+ +
+
+ + + + +
#define UPDATE_GATE_WEIGHT_X4
+
+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nnfunctions_8h.html b/docs/NN/html/arm__nnfunctions_8h.html new file mode 100644 index 0000000..53ec347 --- /dev/null +++ b/docs/NN/html/arm__nnfunctions_8h.html @@ -0,0 +1,429 @@ + + + + + +arm_nnfunctions.h File Reference +CMSIS-NN: arm_nnfunctions.h File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nnfunctions.h File Reference
+
+
+ + + + +

+Macros

#define USE_INTRINSIC
 
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

+Functions

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)
 Basic Q7 convolution function. More...
 
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)
 Basic Q7 convolution function (non-sqaure shape) More...
 
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)
 Basic Q15 convolution function. More...
 
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)
 Fast Q7 convolution function. More...
 
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)
 Fast Q7 convolution function (non-sqaure shape) More...
 
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)
 Fast Q7 version of 1x1 convolution (non-sqaure shape) More...
 
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)
 Q7 version of convolution for RGB image. More...
 
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)
 Fast Q15 convolution function. More...
 
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)
 Fast Q15 convolution function (non-sqaure shape) More...
 
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)
 Q7 depthwise separable convolution function. More...
 
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)
 Q7 depthwise separable convolution function (non-square shape) More...
 
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)
 Q7 basic fully-connected layer function. More...
 
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)
 Q7 opt fully-connected layer function. More...
 
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)
 Q15 basic fully-connected layer function. More...
 
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)
 Q15 opt fully-connected layer function. More...
 
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)
 Mixed Q15-Q7 fully-connected layer function. More...
 
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)
 Mixed Q15-Q7 opt fully-connected layer function. More...
 
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)
 Matrix-Multiplication Kernels for Convolution. More...
 
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)
 Matrix-multiplication function for convolution with reordered columns. More...
 
void arm_relu_q7 (q7_t *data, uint16_t size)
 Q7 RELU function. More...
 
void arm_relu_q15 (q15_t *data, uint16_t size)
 Q15 RELU function. More...
 
void arm_nn_activations_direct_q7 (q7_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type)
 Q7 neural network activation function using direct table look-up. More...
 
void arm_nn_activations_direct_q15 (q15_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type)
 Q15 neural network activation function using direct table look-up. More...
 
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)
 Q7 max pooling function. More...
 
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)
 Q7 average pooling function. More...
 
void arm_softmax_q7 (const q7_t *vec_in, const uint16_t dim_vec, q7_t *p_out)
 Q7 softmax function. More...
 
void arm_softmax_q15 (const q15_t *vec_in, const uint16_t dim_vec, q15_t *p_out)
 Q15 softmax function. More...
 
+

Macro Definition Documentation

+ +
+
+ + + + +
#define USE_INTRINSIC
+
+ +
+
+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+

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. Matrix-multiplication function for convolution

+
Parameters
+ + + + + + + + + +
[in]pApointer to operand A
[in]pInBufferpointer to operand B, always conssists of 2 vectors
[in]ch_im_outnumRow of A
[in]numCol_AnumCol of A
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biasthe bias
[in,out]pOutpointer to output
+
+
+
Returns
The function returns the incremented output pointer
+

Matrix-Multiplication Kernels for Convolution.

+
Parameters
+ + + + + + + + + +
[in]pApointer to operand A
[in]pInBufferpointer to operand B, always conssists of 2 vectors
[in]ch_im_outnumRow of A
[in]numCol_AnumCol of A
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biasthe bias
[in,out]pOutpointer to output
+
+
+
Returns
The function returns the incremented output pointer
+

This function does the matrix multiplication with weight matrix and 2 columns from im2col.

+ +

References NN_ROUND.

+ +

Referenced by arm_convolve_HWC_q7_basic(), arm_convolve_HWC_q7_basic_nonsquare(), and arm_convolve_HWC_q7_RGB().

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + +
[in]pApointer to operand A
[in]pInBufferpointer to operand B, always conssists of 2 vectors
[in]ch_im_outnumRow of A
[in]numCol_AnumCol of A
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biasthe bias
[in,out]pOutpointer to output
+
+
+
Returns
The function returns the incremented output pointer
+
Parameters
+ + + + + + + + + +
[in]pApointer to operand A
[in]pInBufferpointer to operand B, always conssists of 2 vectors
[in]ch_im_outnumRow of A
[in]numCol_AnumCol of A
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biasthe bias
[in,out]pOutpointer to output
+
+
+
Returns
The function returns the incremented output pointer
+

This function assumes that data in pInBuffer are reordered

+ +

References NN_ROUND.

+ +

Referenced by arm_convolve_1x1_HWC_q7_fast_nonsquare(), arm_convolve_HWC_q7_fast(), and arm_convolve_HWC_q7_fast_nonsquare().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nnsupportfunctions_8h.html b/docs/NN/html/arm__nnsupportfunctions_8h.html new file mode 100644 index 0000000..6d4f025 --- /dev/null +++ b/docs/NN/html/arm__nnsupportfunctions_8h.html @@ -0,0 +1,208 @@ + + + + + +arm_nnsupportfunctions.h File Reference +CMSIS-NN: arm_nnsupportfunctions.h File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nnsupportfunctions.h File Reference
+
+
+ + + + + +

+Data Structures

union  arm_nnword
 Union for SIMD access of Q31/Q15/Q7 types. More...
 
+ + + + +

+Macros

#define NN_ROUND(out_shift)
 defition to adding rouding offset More...
 
+ + + + +

+Enumerations

enum  arm_nn_activation_type
 Struct for specifying activation function types. More...
 
+ + + + + + + + + + + + + +

+Functions

void arm_q7_to_q15_no_shift (const q7_t *pSrc, q15_t *pDst, uint32_t blockSize)
 Converts the elements of the Q7 vector to Q15 vector without left-shift. More...
 
void arm_q7_to_q15_reordered_no_shift (const q7_t *pSrc, q15_t *pDst, uint32_t blockSize)
 Converts the elements of the Q7 vector to reordered Q15 vector without left-shift. More...
 
void arm_nn_mult_q15 (q15_t *pSrcA, q15_t *pSrcB, q15_t *pDst, const uint16_t out_shift, uint32_t blockSize)
 Q7 vector multiplication with variable output shifts. More...
 
void arm_nn_mult_q7 (q7_t *pSrcA, q7_t *pSrcB, q7_t *pDst, const uint16_t out_shift, uint32_t blockSize)
 Q7 vector multiplication with variable output shifts. More...
 
+

Macro Definition Documentation

+ + +

Enumeration Type Documentation

+ +
+
+ + + + +
enum arm_nn_activation_type
+
+ + + +
Enumerator
ARM_SIGMOID  +

Sigmoid activation function

+
ARM_TANH  +

Tanh activation function

+
+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__nntables_8c.html b/docs/NN/html/arm__nntables_8c.html new file mode 100644 index 0000000..169fa26 --- /dev/null +++ b/docs/NN/html/arm__nntables_8c.html @@ -0,0 +1,268 @@ + + + + + +arm_nntables.c File Reference +CMSIS-NN: arm_nntables.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_nntables.c File Reference
+
+
+ + + + + + + + + + + + + + + + + + + + + +

+Variables

const q7_t sigmoidTable_q7 [256]
 tables for various activation functions More...
 
const q15_t sigmoidTable_q15 [256]
 tables for various activation functions More...
 
const q15_t sigmoidLTable_q15 [128]
 
const q15_t sigmoidHTable_q15 [192]
 2-way tables for various activation functions More...
 
const q7_t tanhTable_q7 [256]
 
const q15_t tanhTable_q15 [256]
 
const q15_t tanhLTable_q15 [128]
 
const q15_t tanhHTable_q15 [192]
 
+

Variable Documentation

+ +
+
+ + + + +
const q15_t sigmoidHTable_q15[192]
+
+

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

+ +
+
+ +
+
+ + + + +
const q15_t sigmoidLTable_q15[128]
+
+ +
+
+ +
+
+ + + + +
const q15_t sigmoidTable_q15[256]
+
+ +

Referenced by arm_nn_activations_direct_q15().

+ +
+
+ +
+
+ + + + +
const q7_t sigmoidTable_q7[256]
+
+

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

+ +

Referenced by arm_nn_activations_direct_q7().

+ +
+
+ +
+
+ + + + +
const q15_t tanhHTable_q15[192]
+
+ +
+
+ +
+
+ + + + +
const q15_t tanhLTable_q15[128]
+
+ +
+
+ +
+
+ + + + +
const q15_t tanhTable_q15[256]
+
+ +

Referenced by arm_nn_activations_direct_q15().

+ +
+
+ +
+
+ + + + +
const q7_t tanhTable_q7[256]
+
+ +

Referenced by arm_nn_activations_direct_q7().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/arm__pool__q7__HWC_8c.html b/docs/NN/html/arm__pool__q7__HWC_8c.html new file mode 100644 index 0000000..44d93de --- /dev/null +++ b/docs/NN/html/arm__pool__q7__HWC_8c.html @@ -0,0 +1,141 @@ + + + + + +arm_pool_q7_HWC.c File Reference +CMSIS-NN: arm_pool_q7_HWC.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_pool_q7_HWC.c File Reference
+
+
+ + + + + + + + +

+Functions

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)
 Q7 max pooling function. More...
 
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)
 Q7 average pooling function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__q7__to__q15__no__shift_8c.html b/docs/NN/html/arm__q7__to__q15__no__shift_8c.html new file mode 100644 index 0000000..1c311e6 --- /dev/null +++ b/docs/NN/html/arm__q7__to__q15__no__shift_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_q7_to_q15_no_shift.c File Reference +CMSIS-NN: arm_q7_to_q15_no_shift.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_q7_to_q15_no_shift.c File Reference
+
+
+ + + + + +

+Functions

void arm_q7_to_q15_no_shift (const q7_t *pSrc, q15_t *pDst, uint32_t blockSize)
 Converts the elements of the Q7 vector to Q15 vector without left-shift. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__q7__to__q15__reordered__no__shift_8c.html b/docs/NN/html/arm__q7__to__q15__reordered__no__shift_8c.html new file mode 100644 index 0000000..268d282 --- /dev/null +++ b/docs/NN/html/arm__q7__to__q15__reordered__no__shift_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_q7_to_q15_reordered_no_shift.c File Reference +CMSIS-NN: arm_q7_to_q15_reordered_no_shift.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_q7_to_q15_reordered_no_shift.c File Reference
+
+
+ + + + + +

+Functions

void arm_q7_to_q15_reordered_no_shift (const q7_t *pSrc, q15_t *pDst, uint32_t blockSize)
 Converts the elements of the Q7 vector to reordered Q15 vector without left-shift. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__relu__q15_8c.html b/docs/NN/html/arm__relu__q15_8c.html new file mode 100644 index 0000000..fa774ad --- /dev/null +++ b/docs/NN/html/arm__relu__q15_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_relu_q15.c File Reference +CMSIS-NN: arm_relu_q15.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_relu_q15.c File Reference
+
+
+ + + + + +

+Functions

void arm_relu_q15 (q15_t *data, uint16_t size)
 Q15 RELU function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__relu__q7_8c.html b/docs/NN/html/arm__relu__q7_8c.html new file mode 100644 index 0000000..968ad72 --- /dev/null +++ b/docs/NN/html/arm__relu__q7_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_relu_q7.c File Reference +CMSIS-NN: arm_relu_q7.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_relu_q7.c File Reference
+
+
+ + + + + +

+Functions

void arm_relu_q7 (q7_t *data, uint16_t size)
 Q7 RELU function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__softmax__q15_8c.html b/docs/NN/html/arm__softmax__q15_8c.html new file mode 100644 index 0000000..7dee7ba --- /dev/null +++ b/docs/NN/html/arm__softmax__q15_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_softmax_q15.c File Reference +CMSIS-NN: arm_softmax_q15.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_softmax_q15.c File Reference
+
+
+ + + + + +

+Functions

void arm_softmax_q15 (const q15_t *vec_in, const uint16_t dim_vec, q15_t *p_out)
 Q15 softmax function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/arm__softmax__q7_8c.html b/docs/NN/html/arm__softmax__q7_8c.html new file mode 100644 index 0000000..e3f979a --- /dev/null +++ b/docs/NN/html/arm__softmax__q7_8c.html @@ -0,0 +1,138 @@ + + + + + +arm_softmax_q7.c File Reference +CMSIS-NN: arm_softmax_q7.c File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
arm_softmax_q7.c File Reference
+
+
+ + + + + +

+Functions

void arm_softmax_q7 (const q7_t *vec_in, const uint16_t dim_vec, q7_t *p_out)
 Q7 softmax function. More...
 
+
+
+ + + + diff --git a/docs/NN/html/bc_s.png b/docs/NN/html/bc_s.png new file mode 100644 index 0000000..224b29a Binary files /dev/null and b/docs/NN/html/bc_s.png differ diff --git a/docs/NN/html/bdwn.png b/docs/NN/html/bdwn.png new file mode 100644 index 0000000..940a0b9 Binary files /dev/null and b/docs/NN/html/bdwn.png differ diff --git a/docs/NN/html/cifar10_2readme_8txt.html b/docs/NN/html/cifar10_2readme_8txt.html new file mode 100644 index 0000000..62412db --- /dev/null +++ b/docs/NN/html/cifar10_2readme_8txt.html @@ -0,0 +1,129 @@ + + + + + +readme.txt File Reference +CMSIS-NN: readme.txt File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
readme.txt File Reference
+
+
+
+
+ + + + diff --git a/docs/NN/html/classes.html b/docs/NN/html/classes.html new file mode 100644 index 0000000..e988ba0 --- /dev/null +++ b/docs/NN/html/classes.html @@ -0,0 +1,143 @@ + + + + + +Data Structure Index +CMSIS-NN: Data Structure Index + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Data Structure Index
+
+
+ + + + + + +
  n  
+
arm_nnword   
+ +
+
+ + + + diff --git a/docs/NN/html/closed.png b/docs/NN/html/closed.png new file mode 100644 index 0000000..98cc2c9 Binary files /dev/null and b/docs/NN/html/closed.png differ diff --git a/docs/NN/html/cmsis.css b/docs/NN/html/cmsis.css new file mode 100644 index 0000000..bba1010 --- /dev/null +++ b/docs/NN/html/cmsis.css @@ -0,0 +1,1282 @@ +/* The standard CSS for doxygen */ + +body, table, div, p, dl { + font-family: Lucida Grande, Verdana, Geneva, Arial, sans-serif; + font-size: 13px; + line-height: 1.3; +} + +/* CMSIS styles */ + +.style1 { + text-align: center; +} +.style2 { + color: #0000FF; + font-weight: normal; +} +.style3 { + text-align: left; +} +.style4 { + color: #008000; +} +.style5 { + color: #0000FF; +} +.style6 { + color: #000000; + font-style:italic; +} +.mand { + color: #0000FF; +} +.opt { + color: #008000; +} +.cond { + color: #990000; +} + +.choice +{ + background-color:#F7F9D0; +} +.seq +{ + background-color:#C9DECB; +} +.group1 +{ + background-color:#F8F1F1; +} +.group2 +{ + background-color:#DCEDEA; +} + + +ul ul { + list-style-type: disc; +} + +ul ul ul { + list-style-type: disc; +} + +ul.hierarchy { + color: green; +} + +em { + color: #000000; + font-style:italic; +} + + + +/* CMSIS Tables */ +table.cmtab1 { + padding: 4px; + border-collapse: collapse; + border: 1px solid #A3B4D7; + text-align: justify; + width:70%; +} + +th.cmtab1 { + background: #EBEFF6; + font-weight: bold; + height: 28px; +} + +td.cmtab1 { + padding:1px; + text-align: left; +} + +table.cmtable { + border-collapse:collapse; + text-align: justify; +} + +table.cmtable td, table.cmtable th { + border: 1px solid #2D4068; + padding: 3px 7px 2px; +} + +table.cmtable th { + background-color: #EBEFF6; + font-size: 110%; + padding-bottom: 4px; + padding-top: 5px; + text-align:left; +} + +td.MonoTxt { + font-family:"Arial monospaced for SAP"; +} + +td.XML-Token +{ + azimuth: 180; + font-style:italic; + color:Maroon; + z-index:20; + +} + +span.XML-Token +{ + azimuth: 180; + font-style:italic; + color:Maroon; + z-index:20; + +} + +span.h2 +{ + font-size: 120%; + font-weight: bold; +} + +div.new +{ + background-color:#ccffcc; /* light green */ +} + +div.mod +{ + background-color:#ffe6cc; /* light amber */ +} + +div.del +{ + background-color:#ffcccc; /* light red */ +} + +/* @group Heading Levels */ + +h1 { + font-size: 150%; +} + +.title { + font-size: 150%; + font-weight: bold; + margin: 10px 2px; +} + +h2 { + font-size: 120%; +} + +h3 { + font-size: 100%; +} + +h1, h2, h3, h4, h5, h6 { + -webkit-transition: text-shadow 0.5s linear; + -moz-transition: text-shadow 0.5s linear; + -ms-transition: text-shadow 0.5s linear; + -o-transition: text-shadow 0.5s linear; + transition: text-shadow 0.5s linear; + margin-right: 15px; +} + +h1.glow, h2.glow, h3.glow, h4.glow, h5.glow, h6.glow { + text-shadow: 0 0 15px cyan; +} + +dt { + font-weight: bold; +} + +div.multicol { + -moz-column-gap: 1em; + -webkit-column-gap: 1em; + -moz-column-count: 3; + -webkit-column-count: 3; +} + +p.startli, p.startdd, p.starttd { + margin-top: 2px; +} + +p.endli { + margin-bottom: 0px; +} + +p.enddd { + margin-bottom: 4px; +} + +p.endtd { + margin-bottom: 2px; +} + +/* @end */ + +caption { + font-weight: bold; +} + +span.legend { + font-size: 70%; + text-align: center; +} + +h3.version { + font-size: 90%; + text-align: center; +} + +div.qindex, div.navtab{ + background-color: #EBEFF6; + border: 1px solid #A2B4D8; + text-align: center; +} + +div.qindex, div.navpath { + width: 100%; + line-height: 140%; +} + +div.navtab { + margin-right: 15px; +} + +/* @group Link Styling */ + +a { + color: #3A568E; + font-weight: normal; + text-decoration: none; +} + +.contents a:visited { + color: #4464A5; +} + +a:hover { + text-decoration: underline; +} + +a.qindex { + font-weight: bold; +} + +a.qindexHL { + font-weight: bold; + background-color: #9AAED5; + color: #ffffff; + border: 1px double #849CCC; +} + +.contents a.qindexHL:visited { + color: #ffffff; +} + +a.el { + font-weight: bold; +} + +a.elRef { +} + +a.code, a.code:visited { + color: #4665A2; +} + +a.codeRef, a.codeRef:visited { + color: #4665A2; +} + +/* @end */ + +dl.el { + margin-left: -1cm; +} + +pre.fragment { + border: 1px solid #C4CFE5; + background-color: #FBFCFD; + padding: 4px 6px; + margin: 4px 8px 4px 2px; + overflow: auto; + word-wrap: break-word; + font-size: 9pt; + line-height: 125%; + font-family: monospace, fixed; + font-size: 105%; +} + +div.fragment { + padding: 4px; + margin: 4px; + background-color: #FBFCFD; + border: 1px solid #C3CFE6; +} + +div.line { + font-family: monospace, fixed; + font-size: 13px; + line-height: 1.0; + text-wrap: unrestricted; + white-space: -moz-pre-wrap; /* Moz */ + white-space: -pre-wrap; /* Opera 4-6 */ + white-space: -o-pre-wrap; /* Opera 7 */ + white-space: pre-wrap; /* CSS3 */ + word-wrap: break-word; /* IE 5.5+ */ + text-indent: -53px; + padding-left: 53px; + padding-bottom: 0px; + margin: 0px; +} + +span.lineno { + padding-right: 4px; + text-align: right; + border-right: 2px solid #0F0; + background-color: #E8E8E8; + white-space: pre; +} +span.lineno a { + background-color: #D8D8D8; +} + +span.lineno a:hover { + background-color: #C8C8C8; +} + +div.ah { + background-color: black; + font-weight: bold; + color: #ffffff; + margin-bottom: 3px; + margin-top: 3px; + padding: 0.2em; + border: solid thin #333; + border-radius: 0.5em; + -webkit-border-radius: .5em; + -moz-border-radius: .5em; + box-shadow: 2px 2px 3px #999; + -webkit-box-shadow: 2px 2px 3px #999; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 2px 2px 2px; + background-image: -webkit-gradient(linear, left top, left bottom, from(#eee), to(#000),color-stop(0.3, #444)); + background-image: -moz-linear-gradient(center top, #eee 0%, #444 40%, #000); +} + +div.groupHeader { + margin-left: 16px; + margin-top: 12px; + font-weight: bold; +} + +div.groupText { + margin-left: 16px; + font-style: italic; +} + +body { + background-color: white; + color: black; + margin: 0; +} + +div.contents { + margin-top: 10px; + margin-left: 12px; + margin-right: 8px; +} + +td.indexkey { + background-color: #EBEFF6; + font-weight: bold; + border: 1px solid #C3CFE6; + margin: 2px 0px 2px 0; + padding: 2px 10px; + white-space: nowrap; + vertical-align: top; +} + +td.indexvalue { + background-color: #EBEFF6; + border: 1px solid #C3CFE6; + padding: 2px 10px; + margin: 2px 0px; +} + +tr.memlist { + background-color: #EDF1F7; +} + +p.formulaDsp { + text-align: center; +} + +img.formulaDsp { + +} + +img.formulaInl { + vertical-align: middle; +} + +div.center { + text-align: center; + margin-top: 0px; + margin-bottom: 0px; + padding: 0px; +} + +div.center img { + border: 0px; +} + +address.footer { + text-align: right; + padding-right: 12px; +} + +img.footer { + border: 0px; + vertical-align: middle; +} + +/* @group Code Colorization */ + +span.keyword { + color: #008000 +} + +span.keywordtype { + color: #604020 +} + +span.keywordflow { + color: #e08000 +} + +span.comment { + color: #800000 +} + +span.preprocessor { + color: #806020 +} + +span.stringliteral { + color: #002080 +} + +span.charliteral { + color: #008080 +} + +span.vhdldigit { + color: #ff00ff +} + +span.vhdlchar { + color: #000000 +} + +span.vhdlkeyword { + color: #700070 +} + +span.vhdllogic { + color: #ff0000 +} + +blockquote { + background-color: #F7F8FB; + border-left: 2px solid #9AAED5; + margin: 0 24px 0 4px; + padding: 0 12px 0 16px; +} + +/* @end */ + +/* +.search { + color: #003399; + font-weight: bold; +} + +form.search { + margin-bottom: 0px; + margin-top: 0px; +} + +input.search { + font-size: 75%; + color: #000080; + font-weight: normal; + background-color: #e8eef2; +} +*/ + +td.tiny { + font-size: 75%; +} + +.dirtab { + padding: 4px; + border-collapse: collapse; + border: 1px solid #A2B4D8; +} + +th.dirtab { + background: #EBEFF6; + font-weight: bold; +} + +hr { + height: 0px; + border: none; + border-top: 1px solid #4769AD; +} + +hr.footer { + height: 1px; +} + +/* @group Member Descriptions */ + +table.memberdecls { + border-spacing: 0px; + padding: 0px; +} + +.memberdecls td { + -webkit-transition-property: background-color, box-shadow; + -webkit-transition-duration: 0.5s; + -moz-transition-property: background-color, box-shadow; + -moz-transition-duration: 0.5s; + -ms-transition-property: background-color, box-shadow; + -ms-transition-duration: 0.5s; + -o-transition-property: background-color, box-shadow; + -o-transition-duration: 0.5s; + transition-property: background-color, box-shadow; + transition-duration: 0.5s; +} + +.memberdecls td.glow { + background-color: cyan; + box-shadow: 0 0 15px cyan; +} + +.mdescLeft, .mdescRight, +.memItemLeft, .memItemRight, +.memTemplItemLeft, .memTemplItemRight, .memTemplParams { + background-color: #F9FAFC; + border: none; + margin: 4px; + padding: 1px 0 0 8px; +} + +.mdescLeft, .mdescRight { + padding: 0px 8px 4px 8px; + color: #555; +} + +.memItemLeft, .memItemRight, .memTemplParams { + border-top: 1px solid #C3CFE6; +} + +.memItemLeft, .memTemplItemLeft { + white-space: nowrap; +} + +.memItemRight { + width: 100%; +} + +.memTemplParams { + color: #4464A5; + white-space: nowrap; +} + +/* @end */ + +/* @group Member Details */ + +/* Styles for detailed member documentation */ + +.memtemplate { + font-size: 80%; + color: #4464A5; + font-weight: normal; + margin-left: 9px; +} + +.memnav { + background-color: #EBEFF6; + border: 1px solid #A2B4D8; + text-align: center; + margin: 2px; + margin-right: 15px; + padding: 2px; +} + +.mempage { + width: 100%; +} + +.memitem { + padding: 0; + margin-bottom: 10px; + margin-right: 5px; + -webkit-transition: box-shadow 0.5s linear; + -moz-transition: box-shadow 0.5s linear; + -ms-transition: box-shadow 0.5s linear; + -o-transition: box-shadow 0.5s linear; + transition: box-shadow 0.5s linear; +} + +.memitem.glow { + box-shadow: 0 0 15px cyan; +} + +.memname { + font-weight: bold; + margin-left: 6px; +} + +.memname td { + vertical-align: bottom; +} + +.memproto, dl.reflist dt { + border-top: 1px solid #A7B8DA; + border-left: 1px solid #A7B8DA; + border-right: 1px solid #A7B8DA; + padding: 6px 0px 6px 0px; + color: #233456; + font-weight: bold; + text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9); + background-image:url('nav_f.png'); + background-repeat:repeat-x; + background-color: #E2E7F3; + /* opera specific markup */ + box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + border-top-right-radius: 4px; + border-top-left-radius: 4px; + /* firefox specific markup */ + -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px; + -moz-border-radius-topright: 4px; + -moz-border-radius-topleft: 4px; + /* webkit specific markup */ + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + -webkit-border-top-right-radius: 4px; + -webkit-border-top-left-radius: 4px; + +} + +.memdoc, dl.reflist dd { + border-bottom: 1px solid #A7B8DA; + border-left: 1px solid #A7B8DA; + border-right: 1px solid #A7B8DA; + padding: 6px 10px 2px 10px; + background-color: #FBFCFD; + border-top-width: 0; + background-image:url('nav_g.png'); + background-repeat:repeat-x; + background-color: #FFFFFF; + /* opera specific markup */ + border-bottom-left-radius: 4px; + border-bottom-right-radius: 4px; + box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + /* firefox specific markup */ + -moz-border-radius-bottomleft: 4px; + -moz-border-radius-bottomright: 4px; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px; + /* webkit specific markup */ + -webkit-border-bottom-left-radius: 4px; + -webkit-border-bottom-right-radius: 4px; + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); +} + +dl.reflist dt { + padding: 5px; +} + +dl.reflist dd { + margin: 0px 0px 10px 0px; + padding: 5px; +} + +.paramkey { + text-align: right; +} + +.paramtype { + white-space: nowrap; +} + +.paramname { + color: #602020; + white-space: nowrap; +} +.paramname em { + font-style: normal; +} + +.params, .retval, .exception, .tparams { + margin-left: 0px; + padding-left: 0px; +} + +.params .paramname, .retval .paramname { + font-weight: bold; + vertical-align: top; +} + +.params .paramtype { + font-style: italic; + vertical-align: top; +} + +.params .paramdir { + font-family: "courier new",courier,monospace; + vertical-align: top; +} + +table.mlabels { + border-spacing: 0px; +} + +td.mlabels-left { + width: 100%; + padding: 0px; +} + +td.mlabels-right { + vertical-align: bottom; + padding: 0px; + white-space: nowrap; +} + +span.mlabels { + margin-left: 8px; +} + +span.mlabel { + background-color: #708CC4; + border-top:1px solid #5072B7; + border-left:1px solid #5072B7; + border-right:1px solid #C3CFE6; + border-bottom:1px solid #C3CFE6; + text-shadow: none; + color: white; + margin-right: 4px; + padding: 2px 3px; + border-radius: 3px; + font-size: 7pt; + white-space: nowrap; +} + + + +/* @end */ + +/* these are for tree view when not used as main index */ + +div.directory { + margin: 10px 0px; + border-top: 1px solid #A8B8D9; + border-bottom: 1px solid #A8B8D9; + width: 100%; +} + +.directory table { + border-collapse:collapse; +} + +.directory td { + margin: 0px; + padding: 0px; + vertical-align: top; +} + +.directory td.entry { + white-space: nowrap; + padding-right: 6px; +} + +.directory td.entry a { + outline:none; +} + +.directory td.desc { + width: 100%; + padding-left: 6px; + padding-right: 6px; + border-left: 1px solid rgba(0,0,0,0.05); +} + +.directory tr.even { + padding-left: 6px; + background-color: #F7F8FB; +} + +.directory img { + vertical-align: -30%; +} + +.directory .levels { + white-space: nowrap; + width: 100%; + text-align: right; + font-size: 9pt; +} + +.directory .levels span { + cursor: pointer; + padding-left: 2px; + padding-right: 2px; + color: #3A568E; +} + +div.dynheader { + margin-top: 8px; + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +address { + font-style: normal; + color: #293C63; +} + +table.doxtable { + border-collapse:collapse; + margin-top: 4px; + margin-bottom: 4px; +} + +table.doxtable td, table.doxtable th { + border: 1px solid #2B4069; + padding: 3px 7px 2px; +} + +table.doxtable th { + background-color: #EBEFF6; + color: #000000; + font-size: 110%; + padding-bottom: 4px; + padding-top: 5px; +} + +table.fieldtable { + width: 100%; + margin-bottom: 10px; + border: 1px solid #A7B8DA; + border-spacing: 0px; + -moz-border-radius: 4px; + -webkit-border-radius: 4px; + border-radius: 4px; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 2px 2px 2px; + -webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.15); + box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.15); +} + +.fieldtable td, .fieldtable th { + padding: 3px 7px 2px; +} + +.fieldtable td.fieldtype, .fieldtable td.fieldname { + white-space: nowrap; + border-right: 1px solid #A7B8DA; + border-bottom: 1px solid #A7B8DA; + vertical-align: top; +} + +.fieldtable td.fielddoc { + border-bottom: 1px solid #A7B8DA; + width: 100%; +} + +.fieldtable tr:last-child td { + border-bottom: none; +} + +.fieldtable th { + background-image:url('nav_f.png'); + background-repeat:repeat-x; + background-color: #E2E7F3; + font-size: 90%; + color: #233456; + padding-bottom: 4px; + padding-top: 5px; + text-align:left; + -moz-border-radius-topleft: 4px; + -moz-border-radius-topright: 4px; + -webkit-border-top-left-radius: 4px; + -webkit-border-top-right-radius: 4px; + border-top-left-radius: 4px; + border-top-right-radius: 4px; + border-bottom: 1px solid #A7B8DA; +} + + +.tabsearch { + top: 0px; + left: 10px; + height: 36px; + background-image: url('tab_b.png'); + z-index: 101; + overflow: hidden; + font-size: 13px; +} + +.navpath ul +{ + font-size: 11px; + background-image:url('tab_b.png'); + background-repeat:repeat-x; + height:30px; + line-height:30px; + color:#889FCE; + border:solid 1px #C1CDE5; + overflow:hidden; + margin:0px; + padding:0px; +} + +.navpath li +{ + list-style-type:none; + float:left; + padding-left:10px; + padding-right:15px; + background-image:url('bc_s.png'); + background-repeat:no-repeat; + background-position:right; + color:#344D7E; +} + +.navpath li.navelem a +{ + height:32px; + display:block; + text-decoration: none; + outline: none; +} + +.navpath li.navelem a:hover +{ + color:#6583BF; +} + +.navpath li.footer +{ + list-style-type:none; + float:right; + padding-left:10px; + padding-right:15px; + background-image:none; + background-repeat:no-repeat; + background-position:right; + color:#344D7E; + font-size: 8pt; +} + + +div.summary +{ + float: right; + font-size: 8pt; + padding-right: 5px; + width: 50%; + text-align: right; +} + +div.summary a +{ + white-space: nowrap; +} + +div.ingroups +{ + margin-left: 5px; + font-size: 8pt; + padding-left: 5px; + width: 50%; + text-align: left; +} + +div.ingroups a +{ + white-space: nowrap; +} + +div.header +{ + background-image:url('nav_h.png'); + background-repeat:repeat-x; + background-color: #F9FAFC; + margin: 0px; + border-bottom: 1px solid #C3CFE6; +} + +div.headertitle +{ + padding: 5px 5px 5px 7px; +} + +dl +{ + padding: 0 0 0 10px; +} + +/* dl.note, dl.warning, dl.attention, dl.pre, dl.post, dl.invariant, dl.deprecated, dl.todo, dl.test, dl.bug */ +dl.section +{ + margin-left: 0px; + padding-left: 0px; +} + +dl.note +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #D0C000; +} + +dl.warning, dl.attention +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #FF0000; +} + +dl.pre, dl.post, dl.invariant +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #00D000; +} + +dl.deprecated +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #505050; +} + +dl.todo +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #00C0E0; +} + +dl.test +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #3030E0; +} + +dl.bug +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #C08050; +} + +dl.section dd { + margin-bottom: 6px; +} + + +#projectlogo +{ + text-align: center; + vertical-align: bottom; + border-collapse: separate; +} + +#projectlogo img +{ + border: 0px none; +} + +#projectname +{ + font: 300% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 2px 0px; +} + +#projectbrief +{ + font: 120% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 0px; +} + +#projectnumber +{ + font: 50% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 0px; +} + +#titlearea +{ + padding: 0px; + margin: 0px; + width: 100%; + border-bottom: 1px solid #5072B7; +} + +.image +{ + text-align: center; +} + +.dotgraph +{ + text-align: center; +} + +.mscgraph +{ + text-align: center; +} + +.caption +{ + font-weight: bold; +} + +div.zoom +{ + border: 1px solid #8EA4D0; +} + +dl.citelist { + margin-bottom:50px; +} + +dl.citelist dt { + color:#314877; + float:left; + font-weight:bold; + margin-right:10px; + padding:5px; +} + +dl.citelist dd { + margin:2px 0; + padding:5px 0; +} + +div.toc { + padding: 14px 25px; + background-color: #F4F6FA; + border: 1px solid #D7DFEE; + border-radius: 7px 7px 7px 7px; + float: right; + height: auto; + margin: 0 20px 10px 10px; + width: 200px; +} + +div.toc li { + background: url("bdwn.png") no-repeat scroll 0 5px transparent; + font: 10px/1.2 Verdana,DejaVu Sans,Geneva,sans-serif; + margin-top: 5px; + padding-left: 10px; + padding-top: 2px; +} + +div.toc h3 { + font: bold 12px/1.2 Arial,FreeSans,sans-serif; + color: #4464A5; + border-bottom: 0 none; + margin: 0; +} + +div.toc ul { + list-style: none outside none; + border: medium none; + padding: 0px; +} + +div.toc li.level1 { + margin-left: 0px; +} + +div.toc li.level2 { + margin-left: 15px; +} + +div.toc li.level3 { + margin-left: 30px; +} + +div.toc li.level4 { + margin-left: 45px; +} + +.inherit_header { + font-weight: bold; + color: gray; + cursor: pointer; + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.inherit_header td { + padding: 6px 0px 2px 5px; +} + +.inherit { + display: none; +} + +tr.heading h2 { + margin-top: 12px; + margin-bottom: 4px; +} + +@media print +{ + #top { display: none; } + #side-nav { display: none; } + #nav-path { display: none; } + body { overflow:visible; } + h1, h2, h3, h4, h5, h6 { page-break-after: avoid; } + .summary { display: none; } + .memitem { page-break-inside: avoid; } + #doc-content + { + margin-left:0 !important; + height:auto !important; + width:auto !important; + overflow:inherit; + display:inline; + } +} + diff --git a/docs/NN/html/dir_06560e3359c5da94845158f0031c08e8.html b/docs/NN/html/dir_06560e3359c5da94845158f0031c08e8.html new file mode 100644 index 0000000..c96f28d --- /dev/null +++ b/docs/NN/html/dir_06560e3359c5da94845158f0031c08e8.html @@ -0,0 +1,139 @@ + + + + + +NN Directory Reference +CMSIS-NN: NN Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
NN Directory Reference
+
+
+ + + + + + + + +

+Directories

directory  Examples
 
directory  Include
 
directory  Source
 
+
+
+ + + + diff --git a/docs/NN/html/dir_13dc9928808d08450b31fdaf572dfc8e.html b/docs/NN/html/dir_13dc9928808d08450b31fdaf572dfc8e.html new file mode 100644 index 0000000..1807419 --- /dev/null +++ b/docs/NN/html/dir_13dc9928808d08450b31fdaf572dfc8e.html @@ -0,0 +1,145 @@ + + + + + +Source Directory Reference +CMSIS-NN: Source Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Source Directory Reference
+
+
+ + + + + + + + + + + + + + +

+Directories

directory  ActivationFunctions
 
directory  ConvolutionFunctions
 
directory  FullyConnectedFunctions
 
directory  NNSupportFunctions
 
directory  PoolingFunctions
 
directory  SoftmaxFunctions
 
+
+
+ + + + diff --git a/docs/NN/html/dir_17aeddf785065efc95337b880bac512b.html b/docs/NN/html/dir_17aeddf785065efc95337b880bac512b.html new file mode 100644 index 0000000..00b1a1c --- /dev/null +++ b/docs/NN/html/dir_17aeddf785065efc95337b880bac512b.html @@ -0,0 +1,139 @@ + + + + + +Include Directory Reference +CMSIS-NN: Include Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Include Directory Reference
+
+
+ + + + + + + + +

+Files

file  arm_nn_tables.h
 
file  arm_nnfunctions.h
 
file  arm_nnsupportfunctions.h
 
+
+
+ + + + diff --git a/docs/NN/html/dir_1c6ec18b156ae6affcf9513e9ed30cbf.html b/docs/NN/html/dir_1c6ec18b156ae6affcf9513e9ed30cbf.html new file mode 100644 index 0000000..2c12e34 --- /dev/null +++ b/docs/NN/html/dir_1c6ec18b156ae6affcf9513e9ed30cbf.html @@ -0,0 +1,135 @@ + + + + + +ARM Directory Reference +CMSIS-NN: ARM Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
ARM Directory Reference
+
+
+ + + + +

+Directories

directory  arm_nn_examples
 
+
+
+ + + + diff --git a/docs/NN/html/dir_21d6d99be497a80d1e903a1ff5a6bb5a.html b/docs/NN/html/dir_21d6d99be497a80d1e903a1ff5a6bb5a.html new file mode 100644 index 0000000..a25b482 --- /dev/null +++ b/docs/NN/html/dir_21d6d99be497a80d1e903a1ff5a6bb5a.html @@ -0,0 +1,141 @@ + + + + + +cifar10 Directory Reference +CMSIS-NN: cifar10 Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
cifar10 Directory Reference
+
+ +
+ + + + diff --git a/docs/NN/html/dir_42ee8ba91ca7a55df66538ce31ddec49.html b/docs/NN/html/dir_42ee8ba91ca7a55df66538ce31ddec49.html new file mode 100644 index 0000000..e9c3d42 --- /dev/null +++ b/docs/NN/html/dir_42ee8ba91ca7a55df66538ce31ddec49.html @@ -0,0 +1,135 @@ + + + + + +Examples Directory Reference +CMSIS-NN: Examples Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Examples Directory Reference
+
+
+ + + + +

+Directories

directory  ARM
 
+
+
+ + + + diff --git a/docs/NN/html/dir_44941783335eeef51fdbcde02b124fbf.html b/docs/NN/html/dir_44941783335eeef51fdbcde02b124fbf.html new file mode 100644 index 0000000..6f1652b --- /dev/null +++ b/docs/NN/html/dir_44941783335eeef51fdbcde02b124fbf.html @@ -0,0 +1,159 @@ + + + + + +ConvolutionFunctions Directory Reference +CMSIS-NN: ConvolutionFunctions Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
ConvolutionFunctions Directory Reference
+
+ +
+ + + + diff --git a/docs/NN/html/dir_4ad8c19a899a351ef23a1c3a29886c7d.html b/docs/NN/html/dir_4ad8c19a899a351ef23a1c3a29886c7d.html new file mode 100644 index 0000000..3e78878 --- /dev/null +++ b/docs/NN/html/dir_4ad8c19a899a351ef23a1c3a29886c7d.html @@ -0,0 +1,143 @@ + + + + + +NNSupportFunctions Directory Reference +CMSIS-NN: NNSupportFunctions Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
NNSupportFunctions Directory Reference
+
+
+ + + + + + + + + + + + +

+Files

file  arm_nn_mult_q15.c
 
file  arm_nn_mult_q7.c
 
file  arm_nntables.c
 
file  arm_q7_to_q15_no_shift.c
 
file  arm_q7_to_q15_reordered_no_shift.c
 
+
+
+ + + + diff --git a/docs/NN/html/dir_5c060210645429de182d0ec8a79ad82d.html b/docs/NN/html/dir_5c060210645429de182d0ec8a79ad82d.html new file mode 100644 index 0000000..fc9855f --- /dev/null +++ b/docs/NN/html/dir_5c060210645429de182d0ec8a79ad82d.html @@ -0,0 +1,141 @@ + + + + + +ActivationFunctions Directory Reference +CMSIS-NN: ActivationFunctions Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
ActivationFunctions Directory Reference
+
+
+ + + + + + + + + + +

+Files

file  arm_nn_activations_q15.c
 
file  arm_nn_activations_q7.c
 
file  arm_relu_q15.c
 
file  arm_relu_q7.c
 
+
+
+ + + + diff --git a/docs/NN/html/dir_6d5f4079ba9c4513aa4d8d5ca02967b4.html b/docs/NN/html/dir_6d5f4079ba9c4513aa4d8d5ca02967b4.html new file mode 100644 index 0000000..99a8752 --- /dev/null +++ b/docs/NN/html/dir_6d5f4079ba9c4513aa4d8d5ca02967b4.html @@ -0,0 +1,135 @@ + + + + + +PoolingFunctions Directory Reference +CMSIS-NN: PoolingFunctions Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
PoolingFunctions Directory Reference
+
+
+ + + + +

+Files

file  arm_pool_q7_HWC.c
 
+
+
+ + + + diff --git a/docs/NN/html/dir_8e33b5b68f9112312341506c184d7434.html b/docs/NN/html/dir_8e33b5b68f9112312341506c184d7434.html new file mode 100644 index 0000000..26f55a9 --- /dev/null +++ b/docs/NN/html/dir_8e33b5b68f9112312341506c184d7434.html @@ -0,0 +1,145 @@ + + + + + +FullyConnectedFunctions Directory Reference +CMSIS-NN: FullyConnectedFunctions Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
FullyConnectedFunctions Directory Reference
+
+ +
+ + + + diff --git a/docs/NN/html/dir_8ff992d4a3d8f0c2e6b3f2d3952b972b.html b/docs/NN/html/dir_8ff992d4a3d8f0c2e6b3f2d3952b972b.html new file mode 100644 index 0000000..10f5621 --- /dev/null +++ b/docs/NN/html/dir_8ff992d4a3d8f0c2e6b3f2d3952b972b.html @@ -0,0 +1,137 @@ + + + + + +SoftmaxFunctions Directory Reference +CMSIS-NN: SoftmaxFunctions Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
SoftmaxFunctions Directory Reference
+
+
+ + + + + + +

+Files

file  arm_softmax_q15.c
 
file  arm_softmax_q7.c
 
+
+
+ + + + diff --git a/docs/NN/html/dir_a3a0a3f0894883b6608166441e8c3ad3.html b/docs/NN/html/dir_a3a0a3f0894883b6608166441e8c3ad3.html new file mode 100644 index 0000000..5d87c33 --- /dev/null +++ b/docs/NN/html/dir_a3a0a3f0894883b6608166441e8c3ad3.html @@ -0,0 +1,139 @@ + + + + + +gru Directory Reference +CMSIS-NN: gru Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
gru Directory Reference
+
+
+ + + + + + + + +

+Files

file  arm_nnexamples_gru.cpp
 
file  arm_nnexamples_gru_test_data.h
 
file  para_gen.py
 
+
+
+ + + + diff --git a/docs/NN/html/dir_b7d5e60e0ec4c139f7aa9a155c284f70.html b/docs/NN/html/dir_b7d5e60e0ec4c139f7aa9a155c284f70.html new file mode 100644 index 0000000..5e74520 --- /dev/null +++ b/docs/NN/html/dir_b7d5e60e0ec4c139f7aa9a155c284f70.html @@ -0,0 +1,137 @@ + + + + + +arm_nn_examples Directory Reference +CMSIS-NN: arm_nn_examples Directory Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
arm_nn_examples Directory Reference
+
+
+ + + + + + +

+Directories

directory  cifar10
 
directory  gru
 
+
+
+ + + + diff --git a/docs/NN/html/doxygen.css b/docs/NN/html/doxygen.css new file mode 100644 index 0000000..f0f36f8 --- /dev/null +++ b/docs/NN/html/doxygen.css @@ -0,0 +1,1366 @@ +/* The standard CSS for doxygen 1.8.6 */ + +body, table, div, p, dl { + font: 400 14px/22px Roboto,sans-serif; +} + +/* @group Heading Levels */ + +h1.groupheader { + font-size: 150%; +} + +.title { + font: 400 14px/28px Roboto,sans-serif; + font-size: 150%; + font-weight: bold; + margin: 10px 2px; +} + +h2.groupheader { + border-bottom: 1px solid #879ECB; + color: #354C7B; + font-size: 150%; + font-weight: normal; + margin-top: 1.75em; + padding-top: 8px; + padding-bottom: 4px; + width: 100%; +} + +h3.groupheader { + font-size: 100%; +} + +h1, h2, h3, h4, h5, h6 { + -webkit-transition: text-shadow 0.5s linear; + -moz-transition: text-shadow 0.5s linear; + -ms-transition: text-shadow 0.5s linear; + -o-transition: text-shadow 0.5s linear; + transition: text-shadow 0.5s linear; + margin-right: 15px; +} + +h1.glow, h2.glow, h3.glow, h4.glow, h5.glow, h6.glow { + text-shadow: 0 0 15px cyan; +} + +dt { + font-weight: bold; +} + +div.multicol { + -moz-column-gap: 1em; + -webkit-column-gap: 1em; + -moz-column-count: 3; + -webkit-column-count: 3; +} + +p.startli, p.startdd { + margin-top: 2px; +} + +p.starttd { + margin-top: 0px; +} + +p.endli { + margin-bottom: 0px; +} + +p.enddd { + margin-bottom: 4px; +} + +p.endtd { + margin-bottom: 2px; +} + +/* @end */ + +caption { + font-weight: bold; +} + +span.legend { + font-size: 70%; + text-align: center; +} + +h3.version { + font-size: 90%; + text-align: center; +} + +div.qindex, div.navtab{ + background-color: #EBEFF6; + border: 1px solid #A3B4D7; + text-align: center; +} + +div.qindex, div.navpath { + width: 100%; + line-height: 140%; +} + +div.navtab { + margin-right: 15px; +} + +/* @group Link Styling */ + +a { + color: #3D578C; + font-weight: normal; + text-decoration: none; +} + +.contents a:visited { + color: #4665A2; +} + +a:hover { + text-decoration: underline; +} + +a.qindex { + font-weight: bold; +} + +a.qindexHL { + font-weight: bold; + background-color: #9CAFD4; + color: #ffffff; + border: 1px double #869DCA; +} + +.contents a.qindexHL:visited { + color: #ffffff; +} + +a.el { + font-weight: bold; +} + +a.elRef { +} + +a.code, a.code:visited, a.line, a.line:visited { + color: #4665A2; +} + +a.codeRef, a.codeRef:visited, a.lineRef, a.lineRef:visited { + color: #4665A2; +} + +/* @end */ + +dl.el { + margin-left: -1cm; +} + +pre.fragment { + border: 1px solid #C4CFE5; + background-color: #FBFCFD; + padding: 4px 6px; + margin: 4px 8px 4px 2px; + overflow: auto; + word-wrap: break-word; + font-size: 9pt; + line-height: 125%; + font-family: monospace, fixed; + font-size: 105%; +} + +div.fragment { + padding: 4px 6px; + margin: 4px 8px 4px 2px; + background-color: #FBFCFD; + border: 1px solid #C4CFE5; +} + +div.line { + font-family: monospace, fixed; + font-size: 13px; + min-height: 13px; + line-height: 1.0; + text-wrap: unrestricted; + white-space: -moz-pre-wrap; /* Moz */ + white-space: -pre-wrap; /* Opera 4-6 */ + white-space: -o-pre-wrap; /* Opera 7 */ + white-space: pre-wrap; /* CSS3 */ + word-wrap: break-word; /* IE 5.5+ */ + text-indent: -53px; + padding-left: 53px; + padding-bottom: 0px; + margin: 0px; + -webkit-transition-property: background-color, box-shadow; + -webkit-transition-duration: 0.5s; + -moz-transition-property: background-color, box-shadow; + -moz-transition-duration: 0.5s; + -ms-transition-property: background-color, box-shadow; + -ms-transition-duration: 0.5s; + -o-transition-property: background-color, box-shadow; + -o-transition-duration: 0.5s; + transition-property: background-color, box-shadow; + transition-duration: 0.5s; +} + +div.line.glow { + background-color: cyan; + box-shadow: 0 0 10px cyan; +} + + +span.lineno { + padding-right: 4px; + text-align: right; + border-right: 2px solid #0F0; + background-color: #E8E8E8; + white-space: pre; +} +span.lineno a { + background-color: #D8D8D8; +} + +span.lineno a:hover { + background-color: #C8C8C8; +} + +div.ah { + background-color: black; + font-weight: bold; + color: #ffffff; + margin-bottom: 3px; + margin-top: 3px; + padding: 0.2em; + border: solid thin #333; + border-radius: 0.5em; + -webkit-border-radius: .5em; + -moz-border-radius: .5em; + box-shadow: 2px 2px 3px #999; + -webkit-box-shadow: 2px 2px 3px #999; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 2px 2px 2px; + background-image: -webkit-gradient(linear, left top, left bottom, from(#eee), to(#000),color-stop(0.3, #444)); + background-image: -moz-linear-gradient(center top, #eee 0%, #444 40%, #000); +} + +div.groupHeader { + margin-left: 16px; + margin-top: 12px; + font-weight: bold; +} + +div.groupText { + margin-left: 16px; + font-style: italic; +} + +body { + background-color: white; + color: black; + margin: 0; +} + +div.contents { + margin-top: 10px; + margin-left: 12px; + margin-right: 8px; +} + +td.indexkey { + background-color: #EBEFF6; + font-weight: bold; + border: 1px solid #C4CFE5; + margin: 2px 0px 2px 0; + padding: 2px 10px; + white-space: nowrap; + vertical-align: top; +} + +td.indexvalue { + background-color: #EBEFF6; + border: 1px solid #C4CFE5; + padding: 2px 10px; + margin: 2px 0px; +} + +tr.memlist { + background-color: #EEF1F7; +} + +p.formulaDsp { + text-align: center; +} + +img.formulaDsp { + +} + +img.formulaInl { + vertical-align: middle; +} + +div.center { + text-align: center; + margin-top: 0px; + margin-bottom: 0px; + padding: 0px; +} + +div.center img { + border: 0px; +} + +address.footer { + text-align: right; + padding-right: 12px; +} + +img.footer { + border: 0px; + vertical-align: middle; +} + +/* @group Code Colorization */ + +span.keyword { + color: #008000 +} + +span.keywordtype { + color: #604020 +} + +span.keywordflow { + color: #e08000 +} + +span.comment { + color: #800000 +} + +span.preprocessor { + color: #806020 +} + +span.stringliteral { + color: #002080 +} + +span.charliteral { + color: #008080 +} + +span.vhdldigit { + color: #ff00ff +} + +span.vhdlchar { + color: #000000 +} + +span.vhdlkeyword { + color: #700070 +} + +span.vhdllogic { + color: #ff0000 +} + +blockquote { + background-color: #F7F8FB; + border-left: 2px solid #9CAFD4; + margin: 0 24px 0 4px; + padding: 0 12px 0 16px; +} + +/* @end */ + +/* +.search { + color: #003399; + font-weight: bold; +} + +form.search { + margin-bottom: 0px; + margin-top: 0px; +} + +input.search { + font-size: 75%; + color: #000080; + font-weight: normal; + background-color: #e8eef2; +} +*/ + +td.tiny { + font-size: 75%; +} + +.dirtab { + padding: 4px; + border-collapse: collapse; + border: 1px solid #A3B4D7; +} + +th.dirtab { + background: #EBEFF6; + font-weight: bold; +} + +hr { + height: 0px; + border: none; + border-top: 1px solid #4A6AAA; +} + +hr.footer { + height: 1px; +} + +/* @group Member Descriptions */ + +table.memberdecls { + border-spacing: 0px; + padding: 0px; +} + +.memberdecls td, .fieldtable tr { + -webkit-transition-property: background-color, box-shadow; + -webkit-transition-duration: 0.5s; + -moz-transition-property: background-color, box-shadow; + -moz-transition-duration: 0.5s; + -ms-transition-property: background-color, box-shadow; + -ms-transition-duration: 0.5s; + -o-transition-property: background-color, box-shadow; + -o-transition-duration: 0.5s; + transition-property: background-color, box-shadow; + transition-duration: 0.5s; +} + +.memberdecls td.glow, .fieldtable tr.glow { + background-color: cyan; + box-shadow: 0 0 15px cyan; +} + +.mdescLeft, .mdescRight, +.memItemLeft, .memItemRight, +.memTemplItemLeft, .memTemplItemRight, .memTemplParams { + background-color: #F9FAFC; + border: none; + margin: 4px; + padding: 1px 0 0 8px; +} + +.mdescLeft, .mdescRight { + padding: 0px 8px 4px 8px; + color: #555; +} + +.memSeparator { + border-bottom: 1px solid #DEE4F0; + line-height: 1px; + margin: 0px; + padding: 0px; +} + +.memItemLeft, .memTemplItemLeft { + white-space: nowrap; +} + +.memItemRight { + width: 100%; +} + +.memTemplParams { + color: #4665A2; + white-space: nowrap; + font-size: 80%; +} + +/* @end */ + +/* @group Member Details */ + +/* Styles for detailed member documentation */ + +.memtemplate { + font-size: 80%; + color: #4665A2; + font-weight: normal; + margin-left: 9px; +} + +.memnav { + background-color: #EBEFF6; + border: 1px solid #A3B4D7; + text-align: center; + margin: 2px; + margin-right: 15px; + padding: 2px; +} + +.mempage { + width: 100%; +} + +.memitem { + padding: 0; + margin-bottom: 10px; + margin-right: 5px; + -webkit-transition: box-shadow 0.5s linear; + -moz-transition: box-shadow 0.5s linear; + -ms-transition: box-shadow 0.5s linear; + -o-transition: box-shadow 0.5s linear; + transition: box-shadow 0.5s linear; + display: table !important; + width: 100%; +} + +.memitem.glow { + box-shadow: 0 0 15px cyan; +} + +.memname { + font-weight: bold; + margin-left: 6px; +} + +.memname td { + vertical-align: bottom; +} + +.memproto, dl.reflist dt { + border-top: 1px solid #A8B8D9; + border-left: 1px solid #A8B8D9; + border-right: 1px solid #A8B8D9; + padding: 6px 0px 6px 0px; + color: #253555; + font-weight: bold; + text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9); + background-image:url('nav_f.png'); + background-repeat:repeat-x; + background-color: #E2E8F2; + /* opera specific markup */ + box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + border-top-right-radius: 4px; + border-top-left-radius: 4px; + /* firefox specific markup */ + -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px; + -moz-border-radius-topright: 4px; + -moz-border-radius-topleft: 4px; + /* webkit specific markup */ + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + -webkit-border-top-right-radius: 4px; + -webkit-border-top-left-radius: 4px; + +} + +.memdoc, dl.reflist dd { + border-bottom: 1px solid #A8B8D9; + border-left: 1px solid #A8B8D9; + border-right: 1px solid #A8B8D9; + padding: 6px 10px 2px 10px; + background-color: #FBFCFD; + border-top-width: 0; + background-image:url('nav_g.png'); + background-repeat:repeat-x; + background-color: #FFFFFF; + /* opera specific markup */ + border-bottom-left-radius: 4px; + border-bottom-right-radius: 4px; + box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + /* firefox specific markup */ + -moz-border-radius-bottomleft: 4px; + -moz-border-radius-bottomright: 4px; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px; + /* webkit specific markup */ + -webkit-border-bottom-left-radius: 4px; + -webkit-border-bottom-right-radius: 4px; + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); +} + +dl.reflist dt { + padding: 5px; +} + +dl.reflist dd { + margin: 0px 0px 10px 0px; + padding: 5px; +} + +.paramkey { + text-align: right; +} + +.paramtype { + white-space: nowrap; +} + +.paramname { + color: #602020; + white-space: nowrap; +} +.paramname em { + font-style: normal; +} +.paramname code { + line-height: 14px; +} + +.params, .retval, .exception, .tparams { + margin-left: 0px; + padding-left: 0px; +} + +.params .paramname, .retval .paramname { + font-weight: bold; + vertical-align: top; +} + +.params .paramtype { + font-style: italic; + vertical-align: top; +} + +.params .paramdir { + font-family: "courier new",courier,monospace; + vertical-align: top; +} + +table.mlabels { + border-spacing: 0px; +} + +td.mlabels-left { + width: 100%; + padding: 0px; +} + +td.mlabels-right { + vertical-align: bottom; + padding: 0px; + white-space: nowrap; +} + +span.mlabels { + margin-left: 8px; +} + +span.mlabel { + background-color: #728DC1; + border-top:1px solid #5373B4; + border-left:1px solid #5373B4; + border-right:1px solid #C4CFE5; + border-bottom:1px solid #C4CFE5; + text-shadow: none; + color: white; + margin-right: 4px; + padding: 2px 3px; + border-radius: 3px; + font-size: 7pt; + white-space: nowrap; + vertical-align: middle; +} + + + +/* @end */ + +/* these are for tree view when not used as main index */ + +div.directory { + margin: 10px 0px; + border-top: 1px solid #A8B8D9; + border-bottom: 1px solid #A8B8D9; + width: 100%; +} + +.directory table { + border-collapse:collapse; +} + +.directory td { + margin: 0px; + padding: 0px; + vertical-align: top; +} + +.directory td.entry { + white-space: nowrap; + padding-right: 6px; + padding-top: 3px; +} + +.directory td.entry a { + outline:none; +} + +.directory td.entry a img { + border: none; +} + +.directory td.desc { + width: 100%; + padding-left: 6px; + padding-right: 6px; + padding-top: 3px; + border-left: 1px solid rgba(0,0,0,0.05); +} + +.directory tr.even { + padding-left: 6px; + background-color: #F7F8FB; +} + +.directory img { + vertical-align: -30%; +} + +.directory .levels { + white-space: nowrap; + width: 100%; + text-align: right; + font-size: 9pt; +} + +.directory .levels span { + cursor: pointer; + padding-left: 2px; + padding-right: 2px; + color: #3D578C; +} + +div.dynheader { + margin-top: 8px; + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +address { + font-style: normal; + color: #2A3D61; +} + +table.doxtable { + border-collapse:collapse; + margin-top: 4px; + margin-bottom: 4px; +} + +table.doxtable td, table.doxtable th { + border: 1px solid #2D4068; + padding: 3px 7px 2px; +} + +table.doxtable th { + background-color: #374F7F; + color: #FFFFFF; + font-size: 110%; + padding-bottom: 4px; + padding-top: 5px; +} + +table.fieldtable { + /*width: 100%;*/ + margin-bottom: 10px; + border: 1px solid #A8B8D9; + border-spacing: 0px; + -moz-border-radius: 4px; + -webkit-border-radius: 4px; + border-radius: 4px; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 2px 2px 2px; + -webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.15); + box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.15); +} + +.fieldtable td, .fieldtable th { + padding: 3px 7px 2px; +} + +.fieldtable td.fieldtype, .fieldtable td.fieldname { + white-space: nowrap; + border-right: 1px solid #A8B8D9; + border-bottom: 1px solid #A8B8D9; + vertical-align: top; +} + +.fieldtable td.fieldname { + padding-top: 3px; +} + +.fieldtable td.fielddoc { + border-bottom: 1px solid #A8B8D9; + /*width: 100%;*/ +} + +.fieldtable td.fielddoc p:first-child { + margin-top: 0px; +} + +.fieldtable td.fielddoc p:last-child { + margin-bottom: 2px; +} + +.fieldtable tr:last-child td { + border-bottom: none; +} + +.fieldtable th { + background-image:url('nav_f.png'); + background-repeat:repeat-x; + background-color: #E2E8F2; + font-size: 90%; + color: #253555; + padding-bottom: 4px; + padding-top: 5px; + text-align:left; + -moz-border-radius-topleft: 4px; + -moz-border-radius-topright: 4px; + -webkit-border-top-left-radius: 4px; + -webkit-border-top-right-radius: 4px; + border-top-left-radius: 4px; + border-top-right-radius: 4px; + border-bottom: 1px solid #A8B8D9; +} + + +.tabsearch { + top: 0px; + left: 10px; + height: 36px; + background-image: url('tab_b.png'); + z-index: 101; + overflow: hidden; + font-size: 13px; +} + +.navpath ul +{ + font-size: 11px; + background-image:url('tab_b.png'); + background-repeat:repeat-x; + background-position: 0 -5px; + height:30px; + line-height:30px; + color:#8AA0CC; + border:solid 1px #C2CDE4; + overflow:hidden; + margin:0px; + padding:0px; +} + +.navpath li +{ + list-style-type:none; + float:left; + padding-left:10px; + padding-right:15px; + background-image:url('bc_s.png'); + background-repeat:no-repeat; + background-position:right; + color:#364D7C; +} + +.navpath li.navelem a +{ + height:32px; + display:block; + text-decoration: none; + outline: none; + color: #283A5D; + font-family: 'Lucida Grande',Geneva,Helvetica,Arial,sans-serif; + text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9); + text-decoration: none; +} + +.navpath li.navelem a:hover +{ + color:#6884BD; +} + +.navpath li.footer +{ + list-style-type:none; + float:right; + padding-left:10px; + padding-right:15px; + background-image:none; + background-repeat:no-repeat; + background-position:right; + color:#364D7C; + font-size: 8pt; +} + + +div.summary +{ + float: right; + font-size: 8pt; + padding-right: 5px; + width: 50%; + text-align: right; +} + +div.summary a +{ + white-space: nowrap; +} + +div.ingroups +{ + font-size: 8pt; + width: 50%; + text-align: left; +} + +div.ingroups a +{ + white-space: nowrap; +} + +div.header +{ + background-image:url('nav_h.png'); + background-repeat:repeat-x; + background-color: #F9FAFC; + margin: 0px; + border-bottom: 1px solid #C4CFE5; +} + +div.headertitle +{ + padding: 5px 5px 5px 10px; +} + +dl +{ + padding: 0 0 0 10px; +} + +/* dl.note, dl.warning, dl.attention, dl.pre, dl.post, dl.invariant, dl.deprecated, dl.todo, dl.test, dl.bug */ +dl.section +{ + margin-left: 0px; + padding-left: 0px; +} + +dl.note +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #D0C000; +} + +dl.warning, dl.attention +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #FF0000; +} + +dl.pre, dl.post, dl.invariant +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #00D000; +} + +dl.deprecated +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #505050; +} + +dl.todo +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #00C0E0; +} + +dl.test +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #3030E0; +} + +dl.bug +{ + margin-left:-7px; + padding-left: 3px; + border-left:4px solid; + border-color: #C08050; +} + +dl.section dd { + margin-bottom: 6px; +} + + +#projectlogo +{ + text-align: center; + vertical-align: bottom; + border-collapse: separate; +} + +#projectlogo img +{ + border: 0px none; +} + +#projectname +{ + font: 300% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 2px 0px; +} + +#projectbrief +{ + font: 120% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 0px; +} + +#projectnumber +{ + font: 50% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 0px; +} + +#titlearea +{ + padding: 0px; + margin: 0px; + width: 100%; + border-bottom: 1px solid #5373B4; +} + +.image +{ + text-align: center; +} + +.dotgraph +{ + text-align: center; +} + +.mscgraph +{ + text-align: center; +} + +.diagraph +{ + text-align: center; +} + +.caption +{ + font-weight: bold; +} + +div.zoom +{ + border: 1px solid #90A5CE; +} + +dl.citelist { + margin-bottom:50px; +} + +dl.citelist dt { + color:#334975; + float:left; + font-weight:bold; + margin-right:10px; + padding:5px; +} + +dl.citelist dd { + margin:2px 0; + padding:5px 0; +} + +div.toc { + padding: 14px 25px; + background-color: #F4F6FA; + border: 1px solid #D8DFEE; + border-radius: 7px 7px 7px 7px; + float: right; + height: auto; + margin: 0 20px 10px 10px; + width: 200px; +} + +div.toc li { + background: url("bdwn.png") no-repeat scroll 0 5px transparent; + font: 10px/1.2 Verdana,DejaVu Sans,Geneva,sans-serif; + margin-top: 5px; + padding-left: 10px; + padding-top: 2px; +} + +div.toc h3 { + font: bold 12px/1.2 Arial,FreeSans,sans-serif; + color: #4665A2; + border-bottom: 0 none; + margin: 0; +} + +div.toc ul { + list-style: none outside none; + border: medium none; + padding: 0px; +} + +div.toc li.level1 { + margin-left: 0px; +} + +div.toc li.level2 { + margin-left: 15px; +} + +div.toc li.level3 { + margin-left: 30px; +} + +div.toc li.level4 { + margin-left: 45px; +} + +.inherit_header { + font-weight: bold; + color: gray; + cursor: pointer; + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.inherit_header td { + padding: 6px 0px 2px 5px; +} + +.inherit { + display: none; +} + +tr.heading h2 { + margin-top: 12px; + margin-bottom: 4px; +} + +/* tooltip related style info */ + +.ttc { + position: absolute; + display: none; +} + +#powerTip { + cursor: default; + white-space: nowrap; + background-color: white; + border: 1px solid gray; + border-radius: 4px 4px 4px 4px; + box-shadow: 1px 1px 7px gray; + display: none; + font-size: smaller; + max-width: 80%; + opacity: 0.9; + padding: 1ex 1em 1em; + position: absolute; + z-index: 2147483647; +} + +#powerTip div.ttdoc { + color: grey; + font-style: italic; +} + +#powerTip div.ttname a { + font-weight: bold; +} + +#powerTip div.ttname { + font-weight: bold; +} + +#powerTip div.ttdeci { + color: #006318; +} + +#powerTip div { + margin: 0px; + padding: 0px; + font: 12px/16px Roboto,sans-serif; +} + +#powerTip:before, #powerTip:after { + content: ""; + position: absolute; + margin: 0px; +} + +#powerTip.n:after, #powerTip.n:before, +#powerTip.s:after, #powerTip.s:before, +#powerTip.w:after, #powerTip.w:before, +#powerTip.e:after, #powerTip.e:before, +#powerTip.ne:after, #powerTip.ne:before, +#powerTip.se:after, #powerTip.se:before, +#powerTip.nw:after, #powerTip.nw:before, +#powerTip.sw:after, #powerTip.sw:before { + border: solid transparent; + content: " "; + height: 0; + width: 0; + position: absolute; +} + +#powerTip.n:after, #powerTip.s:after, +#powerTip.w:after, #powerTip.e:after, +#powerTip.nw:after, #powerTip.ne:after, +#powerTip.sw:after, #powerTip.se:after { + border-color: rgba(255, 255, 255, 0); +} + +#powerTip.n:before, #powerTip.s:before, +#powerTip.w:before, #powerTip.e:before, +#powerTip.nw:before, #powerTip.ne:before, +#powerTip.sw:before, #powerTip.se:before { + border-color: rgba(128, 128, 128, 0); +} + +#powerTip.n:after, #powerTip.n:before, +#powerTip.ne:after, #powerTip.ne:before, +#powerTip.nw:after, #powerTip.nw:before { + top: 100%; +} + +#powerTip.n:after, #powerTip.ne:after, #powerTip.nw:after { + border-top-color: #ffffff; + border-width: 10px; + margin: 0px -10px; +} +#powerTip.n:before { + border-top-color: #808080; + border-width: 11px; + margin: 0px -11px; +} +#powerTip.n:after, #powerTip.n:before { + left: 50%; +} + +#powerTip.nw:after, #powerTip.nw:before { + right: 14px; +} + +#powerTip.ne:after, #powerTip.ne:before { + left: 14px; +} + +#powerTip.s:after, #powerTip.s:before, +#powerTip.se:after, #powerTip.se:before, +#powerTip.sw:after, #powerTip.sw:before { + bottom: 100%; +} + +#powerTip.s:after, #powerTip.se:after, #powerTip.sw:after { + border-bottom-color: #ffffff; + border-width: 10px; + margin: 0px -10px; +} + +#powerTip.s:before, #powerTip.se:before, #powerTip.sw:before { + border-bottom-color: #808080; + border-width: 11px; + margin: 0px -11px; +} + +#powerTip.s:after, #powerTip.s:before { + left: 50%; +} + +#powerTip.sw:after, #powerTip.sw:before { + right: 14px; +} + +#powerTip.se:after, #powerTip.se:before { + left: 14px; +} + +#powerTip.e:after, #powerTip.e:before { + left: 100%; +} +#powerTip.e:after { + border-left-color: #ffffff; + border-width: 10px; + top: 50%; + margin-top: -10px; +} +#powerTip.e:before { + border-left-color: #808080; + border-width: 11px; + top: 50%; + margin-top: -11px; +} + +#powerTip.w:after, #powerTip.w:before { + right: 100%; +} +#powerTip.w:after { + border-right-color: #ffffff; + border-width: 10px; + top: 50%; + margin-top: -10px; +} +#powerTip.w:before { + border-right-color: #808080; + border-width: 11px; + top: 50%; + margin-top: -11px; +} + +@media print +{ + #top { display: none; } + #side-nav { display: none; } + #nav-path { display: none; } + body { overflow:visible; } + h1, h2, h3, h4, h5, h6 { page-break-after: avoid; } + .summary { display: none; } + .memitem { page-break-inside: avoid; } + #doc-content + { + margin-left:0 !important; + height:auto !important; + width:auto !important; + overflow:inherit; + display:inline; + } +} + diff --git a/docs/NN/html/doxygen.png b/docs/NN/html/doxygen.png new file mode 100644 index 0000000..3ff17d8 Binary files /dev/null and b/docs/NN/html/doxygen.png differ diff --git a/docs/NN/html/dynsections.js b/docs/NN/html/dynsections.js new file mode 100644 index 0000000..ed092c7 --- /dev/null +++ b/docs/NN/html/dynsections.js @@ -0,0 +1,97 @@ +function toggleVisibility(linkObj) +{ + var base = $(linkObj).attr('id'); + var summary = $('#'+base+'-summary'); + var content = $('#'+base+'-content'); + var trigger = $('#'+base+'-trigger'); + var src=$(trigger).attr('src'); + if (content.is(':visible')===true) { + content.hide(); + summary.show(); + $(linkObj).addClass('closed').removeClass('opened'); + $(trigger).attr('src',src.substring(0,src.length-8)+'closed.png'); + } else { + content.show(); + summary.hide(); + $(linkObj).removeClass('closed').addClass('opened'); + $(trigger).attr('src',src.substring(0,src.length-10)+'open.png'); + } + return false; +} + +function updateStripes() +{ + $('table.directory tr'). + removeClass('even').filter(':visible:even').addClass('even'); +} +function toggleLevel(level) +{ + $('table.directory tr').each(function(){ + var l = this.id.split('_').length-1; + var i = $('#img'+this.id.substring(3)); + var a = $('#arr'+this.id.substring(3)); + if (l + + + + +File List +CMSIS-NN: File List + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ + + + + + diff --git a/docs/NN/html/ftv2blank.png b/docs/NN/html/ftv2blank.png new file mode 100644 index 0000000..63c605b Binary files /dev/null and b/docs/NN/html/ftv2blank.png differ diff --git a/docs/NN/html/ftv2cl.png b/docs/NN/html/ftv2cl.png new file mode 100644 index 0000000..132f657 Binary files /dev/null and b/docs/NN/html/ftv2cl.png differ diff --git a/docs/NN/html/ftv2doc.png b/docs/NN/html/ftv2doc.png new file mode 100644 index 0000000..17edabf Binary files /dev/null and b/docs/NN/html/ftv2doc.png differ diff --git a/docs/NN/html/ftv2folderclosed.png b/docs/NN/html/ftv2folderclosed.png new file mode 100644 index 0000000..bb8ab35 Binary files /dev/null and b/docs/NN/html/ftv2folderclosed.png differ diff --git a/docs/NN/html/ftv2folderopen.png b/docs/NN/html/ftv2folderopen.png new file mode 100644 index 0000000..d6c7f67 Binary files /dev/null and b/docs/NN/html/ftv2folderopen.png differ diff --git a/docs/NN/html/ftv2lastnode.png b/docs/NN/html/ftv2lastnode.png new file mode 100644 index 0000000..63c605b Binary files /dev/null and b/docs/NN/html/ftv2lastnode.png differ diff --git a/docs/NN/html/ftv2link.png b/docs/NN/html/ftv2link.png new file mode 100644 index 0000000..17edabf Binary files /dev/null and b/docs/NN/html/ftv2link.png differ diff --git a/docs/NN/html/ftv2mlastnode.png b/docs/NN/html/ftv2mlastnode.png new file mode 100644 index 0000000..0b63f6d Binary files /dev/null and b/docs/NN/html/ftv2mlastnode.png differ diff --git a/docs/NN/html/ftv2mnode.png b/docs/NN/html/ftv2mnode.png new file mode 100644 index 0000000..0b63f6d Binary files /dev/null and b/docs/NN/html/ftv2mnode.png differ diff --git a/docs/NN/html/ftv2mo.png b/docs/NN/html/ftv2mo.png new file mode 100644 index 0000000..4bfb80f Binary files /dev/null and b/docs/NN/html/ftv2mo.png differ diff --git a/docs/NN/html/ftv2node.png b/docs/NN/html/ftv2node.png new file mode 100644 index 0000000..63c605b Binary files /dev/null and b/docs/NN/html/ftv2node.png differ diff --git a/docs/NN/html/ftv2ns.png b/docs/NN/html/ftv2ns.png new file mode 100644 index 0000000..72e3d71 Binary files /dev/null and b/docs/NN/html/ftv2ns.png differ diff --git a/docs/NN/html/ftv2plastnode.png b/docs/NN/html/ftv2plastnode.png new file mode 100644 index 0000000..c6ee22f Binary files /dev/null and b/docs/NN/html/ftv2plastnode.png differ diff --git a/docs/NN/html/ftv2pnode.png b/docs/NN/html/ftv2pnode.png new file mode 100644 index 0000000..c6ee22f Binary files /dev/null and b/docs/NN/html/ftv2pnode.png differ diff --git a/docs/NN/html/ftv2splitbar.png b/docs/NN/html/ftv2splitbar.png new file mode 100644 index 0000000..fe895f2 Binary files /dev/null and b/docs/NN/html/ftv2splitbar.png differ diff --git a/docs/NN/html/ftv2vertline.png b/docs/NN/html/ftv2vertline.png new file mode 100644 index 0000000..63c605b Binary files /dev/null and b/docs/NN/html/ftv2vertline.png differ diff --git a/docs/NN/html/functions.html b/docs/NN/html/functions.html new file mode 100644 index 0000000..fe582a7 --- /dev/null +++ b/docs/NN/html/functions.html @@ -0,0 +1,147 @@ + + + + + +Data Fields +CMSIS-NN: Data Fields + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
Here is a list of all struct and union fields with links to the structures/unions they belong to:
+
+
+ + + + diff --git a/docs/NN/html/functions_vars.html b/docs/NN/html/functions_vars.html new file mode 100644 index 0000000..fcaac60 --- /dev/null +++ b/docs/NN/html/functions_vars.html @@ -0,0 +1,147 @@ + + + + + +Data Fields - Variables +CMSIS-NN: Data Fields - Variables + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + + +
+
+ +
+
+
+ + + + + + diff --git a/docs/NN/html/globals.html b/docs/NN/html/globals.html new file mode 100644 index 0000000..660cf87 --- /dev/null +++ b/docs/NN/html/globals.html @@ -0,0 +1,674 @@ + + + + + +Globals +CMSIS-NN: Globals + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
Here is a list of all functions, variables, defines, enums, and typedefs with links to the files they belong to:
+ +

- a -

+ + +

- c -

+ + +

- d -

+ + +

- f -

+ + +

- g -

+ + +

- h -

+ + +

- i -

+ + +

- m -

+ + +

- n -

+ + +

- o -

+ + +

- p -

+ + +

- q -

+ + +

- r -

+ + +

- s -

+ + +

- t -

+ + +

- u -

+
+
+ + + + diff --git a/docs/NN/html/globals_defs.html b/docs/NN/html/globals_defs.html new file mode 100644 index 0000000..904e120 --- /dev/null +++ b/docs/NN/html/globals_defs.html @@ -0,0 +1,400 @@ + + + + + +Globals +CMSIS-NN: Globals + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+  + +

- c -

+ + +

- d -

+ + +

- h -

+ + +

- i -

+ + +

- n -

+ + +

- p -

+ + +

- r -

+ + +

- u -

+
+
+ + + + diff --git a/docs/NN/html/globals_enum.html b/docs/NN/html/globals_enum.html new file mode 100644 index 0000000..f82edb1 --- /dev/null +++ b/docs/NN/html/globals_enum.html @@ -0,0 +1,139 @@ + + + + + +Globals +CMSIS-NN: Globals + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + +
+
+ +
+
+
+ + + + + + diff --git a/docs/NN/html/globals_eval.html b/docs/NN/html/globals_eval.html new file mode 100644 index 0000000..827f4be --- /dev/null +++ b/docs/NN/html/globals_eval.html @@ -0,0 +1,142 @@ + + + + + +Globals +CMSIS-NN: Globals + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + +
+
+ +
+
+
+ + + + + + diff --git a/docs/NN/html/globals_func.html b/docs/NN/html/globals_func.html new file mode 100644 index 0000000..5e34794 --- /dev/null +++ b/docs/NN/html/globals_func.html @@ -0,0 +1,319 @@ + + + + + +Globals +CMSIS-NN: Globals + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+  + +

- a -

+ + +

- c -

+ + +

- d -

+ + +

- f -

+ + +

- g -

+ + +

- m -

+ + +

- n -

+ + +

- q -

+ + +

- r -

+ + +

- s -

+
+
+ + + + diff --git a/docs/NN/html/globals_vars.html b/docs/NN/html/globals_vars.html new file mode 100644 index 0000000..97a42d2 --- /dev/null +++ b/docs/NN/html/globals_vars.html @@ -0,0 +1,272 @@ + + + + + +Globals +CMSIS-NN: Globals + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+  + +

- c -

+ + +

- h -

+ + +

- i -

+ + +

- o -

+ + +

- r -

+ + +

- s -

+ + +

- t -

+ + +

- u -

+
+
+ + + + diff --git a/docs/NN/html/group__Acti.html b/docs/NN/html/group__Acti.html new file mode 100644 index 0000000..fa8cb48 --- /dev/null +++ b/docs/NN/html/group__Acti.html @@ -0,0 +1,327 @@ + + + + + +Neural Network Activation Functions +CMSIS-NN: Neural Network Activation Functions + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
Neural Network Activation Functions
+
+
+ + + + + + + + + + + + + + +

+Functions

void arm_nn_activations_direct_q15 (q15_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type)
 Q15 neural network activation function using direct table look-up. More...
 
void arm_nn_activations_direct_q7 (q7_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type)
 Q7 neural network activation function using direct table look-up. More...
 
void arm_relu_q15 (q15_t *data, uint16_t size)
 Q15 RELU function. More...
 
void arm_relu_q7 (q7_t *data, uint16_t size)
 Q7 RELU function. More...
 
+

Description

+

Perform activation layers, including ReLU (Rectified Linear Unit), sigmoid and tanh

+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
void arm_nn_activations_direct_q15 (q15_t * data,
uint16_t size,
uint16_t int_width,
arm_nn_activation_type type 
)
+
+
Parameters
+ + + + + +
[in,out]datapointer to input
[in]sizenumber of elements
[in]int_widthbit-width of the integer part, assume to be smaller than 3
[in]typetype of activation functions
+
+
+
Returns
none.
+

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.

+ +

References ARM_SIGMOID, ARM_TANH, sigmoidTable_q15, and tanhTable_q15.

+ +

Referenced by gru_example().

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
void arm_nn_activations_direct_q7 (q7_t * data,
uint16_t size,
uint16_t int_width,
arm_nn_activation_type type 
)
+
+
Parameters
+ + + + + +
[in,out]datapointer to input
[in]sizenumber of elements
[in]int_widthbit-width of the integer part, assume to be smaller than 3
[in]typetype of activation functions
+
+
+
Returns
none.
+

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.

+ +

References ARM_SIGMOID, ARM_TANH, sigmoidTable_q7, and tanhTable_q7.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + +
void arm_relu_q15 (q15_t * data,
uint16_t size 
)
+
+
Parameters
+ + + +
[in,out]datapointer to input
[in]sizenumber of elements
+
+
+
Returns
none.
+

Optimized relu with QSUB instructions.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + +
void arm_relu_q7 (q7_t * data,
uint16_t size 
)
+
+
Parameters
+ + + +
[in,out]datapointer to input
[in]sizenumber of elements
+
+
+
Returns
none.
+

Optimized relu with QSUB instructions.

+ +

Referenced by main().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/group__Acti.js b/docs/NN/html/group__Acti.js new file mode 100644 index 0000000..4fe404f --- /dev/null +++ b/docs/NN/html/group__Acti.js @@ -0,0 +1,7 @@ +var group__Acti = +[ + [ "arm_nn_activations_direct_q15", "group__Acti.html#ga8932b57c8d0ee757511af2d40dcc11e7", null ], + [ "arm_nn_activations_direct_q7", "group__Acti.html#ga79f11131ae6767d60e03b1f6506b1af8", null ], + [ "arm_relu_q15", "group__Acti.html#ga53bcc00e54b802919bb3c89c143ee5ba", null ], + [ "arm_relu_q7", "group__Acti.html#ga638e803b4fe00426f401783a6255ca30", null ] +]; \ No newline at end of file diff --git a/docs/NN/html/group__CNNExample.html b/docs/NN/html/group__CNNExample.html new file mode 100644 index 0000000..ffebf32 --- /dev/null +++ b/docs/NN/html/group__CNNExample.html @@ -0,0 +1,160 @@ + + + + + +Convolutional Neural Network Example +CMSIS-NN: Convolutional Neural Network Example + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Convolutional Neural Network Example
+
+
+
Description:
+
Demonstrates a convolutional neural network (CNN) example with the use of convolution, ReLU activation, pooling and fully-connected functions.
+
Model definition:
+
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 im2col data.
+
+CIFAR10_CNN.gif +
+Neural Network model definition
+
Variables Description:
+
    +
  • conv1_wt, conv2_wt, conv3_wt are convolution layer weight matrices
  • +
  • conv1_bias, conv2_bias, conv3_bias are convolution layer bias arrays
  • +
  • ip1_wt, ip1_bias point to fully-connected layer weights and biases
  • +
  • input_data points to the input image data
  • +
  • output_data points to the classification output
  • +
  • col_buffer is a buffer to store the im2col output
  • +
  • scratch_buffer is used to store the activation data (intermediate layer outputs)
  • +
+
+
CMSIS DSP Software Library Functions Used:
+
+
+

Refer arm_nnexamples_cifar10.cpp

+
[1] https://github.com/BVLC/caffe
+
+
+ + + + diff --git a/docs/NN/html/group__FC.html b/docs/NN/html/group__FC.html new file mode 100644 index 0000000..659cf6d --- /dev/null +++ b/docs/NN/html/group__FC.html @@ -0,0 +1,755 @@ + + + + + +Fully-connected Layer Functions +CMSIS-NN: Fully-connected Layer Functions + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
Fully-connected Layer Functions
+
+
+ + + + + + + + + + + + + + + + + + + + +

+Functions

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)
 Mixed Q15-Q7 fully-connected layer function. More...
 
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)
 Mixed Q15-Q7 opt fully-connected layer function. More...
 
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)
 Q15 opt fully-connected layer function. More...
 
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)
 Q15 opt fully-connected layer function. More...
 
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)
 Q7 basic fully-connected layer function. More...
 
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)
 Q7 opt fully-connected layer function. More...
 
+

Description

+

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.

+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + +
[in]pVpointer to input vector
[in]pMpointer to matrix weights
[in]dim_veclength of the vector
[in]num_of_rowsnumber of rows in weight matrix
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biaspointer to bias
[in,out]pOutpointer to output vector
[in,out]vec_bufferpointer to buffer space for input
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+

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

+ +

References NN_ROUND.

+ +

Referenced by gru_example().

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + +
[in]pVpointer to input vector
[in]pMpointer to matrix weights
[in]dim_veclength of the vector
[in]num_of_rowsnumber of rows in weight matrix
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biaspointer to bias
[in,out]pOutpointer to output vector
[in,out]vec_bufferpointer to buffer space for input
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+

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 |

+ +

References NN_ROUND.

+ +

Referenced by gru_example().

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+

Q15 basic fully-connected layer function.

+
Parameters
+ + + + + + + + + + +
[in]pVpointer to input vector
[in]pMpointer to matrix weights
[in]dim_veclength of the vector
[in]num_of_rowsnumber of rows in weight matrix
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biaspointer to bias
[in,out]pOutpointer to output vector
[in,out]vec_bufferpointer to buffer space for input
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+

Buffer size:

+

vec_buffer size: 0

+ +

References NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + +
[in]pVpointer to input vector
[in]pMpointer to matrix weights
[in]dim_veclength of the vector
[in]num_of_rowsnumber of rows in weight matrix
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biaspointer to bias
[in,out]pOutpointer to output vector
[in,out]vec_bufferpointer to buffer space for input
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+

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 |

+ +

References NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + +
[in]pVpointer to input vector
[in]pMpointer to matrix weights
[in]dim_veclength of the vector
[in]num_of_rowsnumber of rows in weight matrix
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biaspointer to bias
[in,out]pOutpointer to output vector
[in,out]vec_bufferpointer to buffer space for input
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+

Buffer size:

+

vec_buffer size: dim_vec

+

This basic function is designed to work with regular weight matrix without interleaving.

+ +

References arm_q7_to_q15_reordered_no_shift(), and NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + +
[in]pVpointer to input vector
[in]pMpointer to matrix weights
[in]dim_veclength of the vector
[in]num_of_rowsnumber of rows in weight matrix
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in]biaspointer to bias
[in,out]pOutpointer to output vector
[in,out]vec_bufferpointer to buffer space for input
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+

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 |

+ +

References arm_q7_to_q15_reordered_no_shift(), and NN_ROUND.

+ +

Referenced by main().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/group__FC.js b/docs/NN/html/group__FC.js new file mode 100644 index 0000000..fb57520 --- /dev/null +++ b/docs/NN/html/group__FC.js @@ -0,0 +1,9 @@ +var group__FC = +[ + [ "arm_fully_connected_mat_q7_vec_q15", "group__FC.html#ga4a1521e7532a1e62d71f3b12762016e2", null ], + [ "arm_fully_connected_mat_q7_vec_q15_opt", "group__FC.html#gae3857bb6375692e81dde8cbd70adec08", null ], + [ "arm_fully_connected_q15", "group__FC.html#gaac666c212b209e636c2369dd5c75d0dc", null ], + [ "arm_fully_connected_q15_opt", "group__FC.html#ga062912078da113f5dd2004fd919a0ff2", null ], + [ "arm_fully_connected_q7", "group__FC.html#ga8b7e0c2e989e8c75f0dc789f3115323d", null ], + [ "arm_fully_connected_q7_opt", "group__FC.html#gaf82b71ef472a38f8fc9ac414d9d07e67", null ] +]; \ No newline at end of file diff --git a/docs/NN/html/group__GRUExample.html b/docs/NN/html/group__GRUExample.html new file mode 100644 index 0000000..57739b2 --- /dev/null +++ b/docs/NN/html/group__GRUExample.html @@ -0,0 +1,162 @@ + + + + + +Gated Recurrent Unit Example +CMSIS-NN: Gated Recurrent Unit Example + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Gated Recurrent Unit Example
+
+
+
Description:
+
Demonstrates a gated recurrent unit (GRU) example with the use of fully-connected, Tanh/Sigmoid activation functions.
+
Model definition:
+
GRU is a type of recurrent neural network (RNN). It contains two sigmoid gates and one hidden state.
+
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] 
+GRU.gif +
+Gate Recurrent Unit Diagram
+
+
Variables Description:
+
    +
  • update_gate_weights, reset_gate_weights, hidden_state_weights are weights corresponding to update gate (W_z), reset gate (W_r), and hidden state (W_n).
  • +
  • update_gate_bias, reset_gate_bias, hidden_state_bias are layer bias arrays
  • +
  • test_input1, test_input2, test_history are the inputs and initial history
  • +
+
+
The buffer is allocated as:
+
| reset | input | history | update | hidden_state |
+
In this way, the concatination is automatically done since (reset, input) and (input, history) are physically concatinated in memory.
+
The ordering of the weight matrix should be adjusted accordingly.
+
CMSIS DSP Software Library Functions Used:
+
+
+

Refer arm_nnexamples_gru.cpp

+
+
+ + + + diff --git a/docs/NN/html/group__NNBasicMath.html b/docs/NN/html/group__NNBasicMath.html new file mode 100644 index 0000000..2521a50 --- /dev/null +++ b/docs/NN/html/group__NNBasicMath.html @@ -0,0 +1,261 @@ + + + + + +Basic Math Functions for Neural Network Computation +CMSIS-NN: Basic Math Functions for Neural Network Computation + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
Basic Math Functions for Neural Network Computation
+
+
+ + + + + + + + +

+Functions

void arm_nn_mult_q15 (q15_t *pSrcA, q15_t *pSrcB, q15_t *pDst, const uint16_t out_shift, uint32_t blockSize)
 Q7 vector multiplication with variable output shifts. More...
 
void arm_nn_mult_q7 (q7_t *pSrcA, q7_t *pSrcB, q7_t *pDst, const uint16_t out_shift, uint32_t blockSize)
 Q7 vector multiplication with variable output shifts. More...
 
+

Description

+

Basic Math Functions for Neural Network Computation

+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
void arm_nn_mult_q15 (q15_t * pSrcA,
q15_t * pSrcB,
q15_t * pDst,
const uint16_t out_shift,
uint32_t blockSize 
)
+
+
Parameters
+ + + + + + +
[in]*pSrcApointer to the first input vector
[in]*pSrcBpointer to the second input vector
[out]*pDstpointer to the output vector
[in]out_shiftamount of right-shift for output
[in]blockSizenumber of samples in each vector
+
+
+
Returns
none.
+

Scaling and Overflow Behavior:

+
The function uses saturating arithmetic. Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated.
+ +

References NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
void arm_nn_mult_q7 (q7_t * pSrcA,
q7_t * pSrcB,
q7_t * pDst,
const uint16_t out_shift,
uint32_t blockSize 
)
+
+
Parameters
+ + + + + + +
[in]*pSrcApointer to the first input vector
[in]*pSrcBpointer to the second input vector
[out]*pDstpointer to the output vector
[in]out_shiftamount of right-shift for output
[in]blockSizenumber of samples in each vector
+
+
+
Returns
none.
+

Scaling and Overflow Behavior:

+
The function uses saturating arithmetic. Results outside of the allowable Q7 range [0x80 0x7F] will be saturated.
+ +

References NN_ROUND.

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/group__NNBasicMath.js b/docs/NN/html/group__NNBasicMath.js new file mode 100644 index 0000000..f2a5b73 --- /dev/null +++ b/docs/NN/html/group__NNBasicMath.js @@ -0,0 +1,5 @@ +var group__NNBasicMath = +[ + [ "arm_nn_mult_q15", "group__NNBasicMath.html#ga08f8340aa6533271b3aa6d211614fe22", null ], + [ "arm_nn_mult_q7", "group__NNBasicMath.html#gad46c9ab012cceda8ce6681c687a58c70", null ] +]; \ No newline at end of file diff --git a/docs/NN/html/group__NNConv.html b/docs/NN/html/group__NNConv.html new file mode 100644 index 0000000..b7f1ff6 --- /dev/null +++ b/docs/NN/html/group__NNConv.html @@ -0,0 +1,1796 @@ + + + + + +Neural Network Convolution Functions +CMSIS-NN: Neural Network Convolution Functions + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
Neural Network Convolution Functions
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

+Functions

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)
 Fast Q7 version of 1x1 convolution (non-sqaure shape) More...
 
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)
 Basic Q15 convolution function. More...
 
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)
 Fast Q15 convolution function. More...
 
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)
 Fast Q15 convolution function (non-sqaure shape) More...
 
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)
 Basic Q7 convolution function. More...
 
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)
 Basic Q7 convolution function (non-sqaure shape) More...
 
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)
 Fast Q7 convolution function. More...
 
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)
 Fast Q7 convolution function (non-sqaure shape) More...
 
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)
 Q7 convolution function for RGB image. More...
 
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)
 Q7 depthwise separable convolution function. More...
 
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)
 Q7 depthwise separable convolution function (non-square shape) More...
 
+

Description

+

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.

+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_in_xinput tensor dimention x
[in]dim_im_in_yinput tensor dimention y
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernel_xfilter kernel size x
[in]dim_kernel_yfilter kernel size y
[in]padding_xpadding size x
[in]padding_ypadding size y
[in]stride_xconvolution stride x
[in]stride_yconvolution stride y
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_out_xoutput tensor dimension x
[in]dim_im_out_youtput tensor dimension y
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
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

+ +

References arm_nn_mat_mult_kernel_q7_q15_reordered(), arm_q7_to_q15_reordered_no_shift(), and NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_ininput tensor dimention
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernelfilter kernel size
[in]paddingpadding sizes
[in]strideconvolution stride
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_outoutput tensor dimension
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+

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.

+ +

References NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_ininput tensor dimention
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernelfilter kernel size
[in]paddingpadding sizes
[in]strideconvolution stride
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_outoutput tensor dimension
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
The function returns either ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking.
+

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

+ +

References NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_in_xinput tensor dimention x
[in]dim_im_in_yinput tensor dimention y
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernel_xfilter kernel size x
[in]dim_kernel_yfilter kernel size y
[in]padding_xpadding size x
[in]padding_ypadding size y
[in]stride_xconvolution stride x
[in]stride_yconvolution stride y
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_out_xoutput tensor dimension x
[in]dim_im_out_youtput tensor dimension y
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
The function returns either ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking.
+

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

+ +

References NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_ininput tensor dimention
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernelfilter kernel size
[in]paddingpadding sizes
[in]strideconvolution stride
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_outoutput tensor dimension
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+

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.

+ +

References arm_nn_mat_mult_kernel_q7_q15(), arm_q7_to_q15_no_shift(), and NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_in_xinput tensor dimention x
[in]dim_im_in_yinput tensor dimention y
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernel_xfilter kernel size x
[in]dim_kernel_yfilter kernel size y
[in]padding_xpadding size x
[in]padding_ypadding size y
[in]stride_xconvolution stride x
[in]stride_yconvolution stride y
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_out_xoutput tensor dimension x
[in]dim_im_out_youtput tensor dimension y
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
The function returns ARM_MATH_SUCCESS
+ +

References arm_nn_mat_mult_kernel_q7_q15(), arm_q7_to_q15_no_shift(), and NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_ininput tensor dimention
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernelfilter kernel size
[in]paddingpadding sizes
[in]strideconvolution stride
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_outoutput tensor dimension
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
The function returns either ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking.
+

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.

+ +

References arm_nn_mat_mult_kernel_q7_q15_reordered(), arm_q7_to_q15_reordered_no_shift(), and NN_ROUND.

+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_in_xinput tensor dimention x
[in]dim_im_in_yinput tensor dimention y
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernel_xfilter kernel size x
[in]dim_kernel_yfilter kernel size y
[in]padding_xpadding size x
[in]padding_ypadding size y
[in]stride_xconvolution stride x
[in]stride_yconvolution stride y
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_out_xoutput tensor dimension x
[in]dim_im_out_youtput tensor dimension y
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
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

+ +

References arm_nn_mat_mult_kernel_q7_q15_reordered(), arm_q7_to_q15_reordered_no_shift(), and NN_ROUND.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+

Q7 version of convolution for RGB image.

+
Parameters
+ + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_ininput tensor dimention
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernelfilter kernel size
[in]paddingpadding sizes
[in]strideconvolution stride
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_outoutput tensor dimension
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
The function returns either ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking.
+

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.

+ +

References arm_nn_mat_mult_kernel_q7_q15(), arm_nnword::half_words, NN_ROUND, and arm_nnword::word.

+ +

Referenced by main().

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_ininput tensor dimention
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernelfilter kernel size
[in]paddingpadding sizes
[in]strideconvolution stride
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_outoutput tensor dimension
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
The function returns either ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking.
+

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)

+ +

References arm_nnword::bytes, NN_ROUND, and arm_nnword::word.

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + + + + + + + + + + + + +
[in]Im_inpointer to input tensor
[in]dim_im_in_xinput tensor dimention x
[in]dim_im_in_yinput tensor dimention y
[in]ch_im_innumber of input tensor channels
[in]wtpointer to kernel weights
[in]ch_im_outnumber of filters, i.e., output tensor channels
[in]dim_kernel_xfilter kernel size x
[in]dim_kernel_yfilter kernel size y
[in]padding_xpadding sizes x
[in]padding_ypadding sizes y
[in]stride_xconvolution stride x
[in]stride_yconvolution stride y
[in]biaspointer to bias
[in]bias_shiftamount of left-shift for bias
[in]out_shiftamount of right-shift for output
[in,out]Im_outpointer to output tensor
[in]dim_im_out_xoutput tensor dimension x
[in]dim_im_out_youtput tensor dimension y
[in,out]bufferApointer to buffer space for input
[in,out]bufferBpointer to buffer space for output
+
+
+
Returns
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

+ +

References arm_nnword::bytes, NN_ROUND, and arm_nnword::word.

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/group__NNConv.js b/docs/NN/html/group__NNConv.js new file mode 100644 index 0000000..0aad363 --- /dev/null +++ b/docs/NN/html/group__NNConv.js @@ -0,0 +1,14 @@ +var group__NNConv = +[ + [ "arm_convolve_1x1_HWC_q7_fast_nonsquare", "group__NNConv.html#ga110adcfdaab356c750c6270aa5e05f29", null ], + [ "arm_convolve_HWC_q15_basic", "group__NNConv.html#ga55701f213b198084b52eab53097f1f58", null ], + [ "arm_convolve_HWC_q15_fast", "group__NNConv.html#ga4efb1ccbbaa7dd936961989dcb443f50", null ], + [ "arm_convolve_HWC_q15_fast_nonsquare", "group__NNConv.html#ga614ec3b71eb96e29952ec3f09e7b9c3c", null ], + [ "arm_convolve_HWC_q7_basic", "group__NNConv.html#ga210ae8d8fc1d12ee15b41f1fa6947681", null ], + [ "arm_convolve_HWC_q7_basic_nonsquare", "group__NNConv.html#ga4501fa22c0836002aa47ccc313dce252", null ], + [ "arm_convolve_HWC_q7_fast", "group__NNConv.html#gae00d3c1285907d59657369fc98bcc83f", null ], + [ "arm_convolve_HWC_q7_fast_nonsquare", "group__NNConv.html#gabc6d6b991024e9e5c5cdbd7489de88ef", null ], + [ "arm_convolve_HWC_q7_RGB", "group__NNConv.html#ga98f2ead67d7cbdf558b0cd8a3b8fc148", null ], + [ "arm_depthwise_separable_conv_HWC_q7", "group__NNConv.html#gad3d21b3bc6dbd6f3b97d01104349cb0a", null ], + [ "arm_depthwise_separable_conv_HWC_q7_nonsquare", "group__NNConv.html#ga32ac508c5467813a84f74f96655dc697", null ] +]; \ No newline at end of file diff --git a/docs/NN/html/group__Pooling.html b/docs/NN/html/group__Pooling.html new file mode 100644 index 0000000..89700d3 --- /dev/null +++ b/docs/NN/html/group__Pooling.html @@ -0,0 +1,321 @@ + + + + + +Neural Network Pooling Functions +CMSIS-NN: Neural Network Pooling Functions + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
Neural Network Pooling Functions
+
+
+ + + + + + + + +

+Functions

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)
 Q7 max pooling function. More...
 
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)
 Q7 average pooling function. More...
 
+

Description

+

Perform pooling functions, including max pooling and average pooling

+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + +
[in,out]Im_inpointer to input tensor
[in]dim_im_ininput tensor dimention
[in]ch_im_innumber of input tensor channels
[in]dim_kernelfilter kernel size
[in]paddingpadding sizes
[in]strideconvolution stride
[in]dim_im_outoutput tensor dimension
[in,out]bufferApointer to buffer space for input
[in,out]Im_outpointer to output tensor
+
+
+
Returns
none.
+

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.

+ +

References arm_q7_to_q15_no_shift().

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
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 
)
+
+
Parameters
+ + + + + + + + + + +
[in,out]Im_inpointer to input tensor
[in]dim_im_ininput tensor dimention
[in]ch_im_innumber of input tensor channels
[in]dim_kernelfilter kernel size
[in]paddingpadding sizes
[in]strideconvolution stride
[in]dim_im_outoutput tensor dimension
[in,out]bufferApointer to buffer space for input
[in,out]Im_outpointer to output tensor
+
+
+
Returns
none.
+

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.

+ +

Referenced by main().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/group__Pooling.js b/docs/NN/html/group__Pooling.js new file mode 100644 index 0000000..5f1682b --- /dev/null +++ b/docs/NN/html/group__Pooling.js @@ -0,0 +1,5 @@ +var group__Pooling = +[ + [ "arm_avepool_q7_HWC", "group__Pooling.html#gae4a7b07f97ec4313524c9fb9fbcb1f6a", null ], + [ "arm_maxpool_q7_HWC", "group__Pooling.html#ga99afcdcc61eaf429ab3ee823702e44ce", null ] +]; \ No newline at end of file diff --git a/docs/NN/html/group__Softmax.html b/docs/NN/html/group__Softmax.html new file mode 100644 index 0000000..b8c8091 --- /dev/null +++ b/docs/NN/html/group__Softmax.html @@ -0,0 +1,233 @@ + + + + + +Softmax Functions +CMSIS-NN: Softmax Functions + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
Softmax Functions
+
+
+ + + + + + + + +

+Functions

void arm_softmax_q15 (const q15_t *vec_in, const uint16_t dim_vec, q15_t *p_out)
 Q15 softmax function. More...
 
void arm_softmax_q7 (const q7_t *vec_in, const uint16_t dim_vec, q7_t *p_out)
 Q7 softmax function. More...
 
+

Description

+

EXP(2) based softmax function

+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + +
void arm_softmax_q15 (const q15_t * vec_in,
const uint16_t dim_vec,
q15_t * p_out 
)
+
+
Parameters
+ + + + +
[in]vec_inpointer to input vector
[in]dim_vecinput vector dimention
[out]p_outpointer to output vector
+
+
+
Returns
none.
+

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_q7 (const q7_t * vec_in,
const uint16_t dim_vec,
q7_t * p_out 
)
+
+
Parameters
+ + + + +
[in]vec_inpointer to input vector
[in]dim_vecinput vector dimention
[out]p_outpointer to output vector
+
+
+
Returns
none.
+

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.

+ +

Referenced by main().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/group__Softmax.js b/docs/NN/html/group__Softmax.js new file mode 100644 index 0000000..c190510 --- /dev/null +++ b/docs/NN/html/group__Softmax.js @@ -0,0 +1,5 @@ +var group__Softmax = +[ + [ "arm_softmax_q15", "group__Softmax.html#ga1cacd8b84b8363079311987d0016ebe5", null ], + [ "arm_softmax_q7", "group__Softmax.html#ga89aff212a97a3cf32d9d7ddf11a8f43e", null ] +]; \ No newline at end of file diff --git a/docs/NN/html/group__groupNN.html b/docs/NN/html/group__groupNN.html new file mode 100644 index 0000000..cd1a13c --- /dev/null +++ b/docs/NN/html/group__groupNN.html @@ -0,0 +1,146 @@ + + + + + +Neural Network Functions +CMSIS-NN: Neural Network Functions + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
Neural Network Functions
+
+
+ + + + + + + + + + + + +

+Content

 Neural Network Activation Functions
 
 Neural Network Convolution Functions
 
 Fully-connected Layer Functions
 
 Neural Network Pooling Functions
 
 Softmax Functions
 
+

Description

+

These functions perform basic operations for neural network layers.

+
+
+ + + + diff --git a/docs/NN/html/group__groupNN.js b/docs/NN/html/group__groupNN.js new file mode 100644 index 0000000..3585e3a --- /dev/null +++ b/docs/NN/html/group__groupNN.js @@ -0,0 +1,8 @@ +var group__groupNN = +[ + [ "Neural Network Activation Functions", "group__Acti.html", "group__Acti" ], + [ "Neural Network Convolution Functions", "group__NNConv.html", "group__NNConv" ], + [ "Fully-connected Layer Functions", "group__FC.html", "group__FC" ], + [ "Neural Network Pooling Functions", "group__Pooling.html", "group__Pooling" ], + [ "Softmax Functions", "group__Softmax.html", "group__Softmax" ] +]; \ No newline at end of file diff --git a/docs/NN/html/group__nndata__convert.html b/docs/NN/html/group__nndata__convert.html new file mode 100644 index 0000000..b845dc1 --- /dev/null +++ b/docs/NN/html/group__nndata__convert.html @@ -0,0 +1,242 @@ + + + + + +Neural Network Data Conversion Functions +CMSIS-NN: Neural Network Data Conversion Functions + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
Neural Network Data Conversion Functions
+
+
+ + + + + + + + +

+Functions

void arm_q7_to_q15_no_shift (const q7_t *pSrc, q15_t *pDst, uint32_t blockSize)
 Converts the elements of the Q7 vector to Q15 vector without left-shift. More...
 
void arm_q7_to_q15_reordered_no_shift (const q7_t *pSrc, q15_t *pDst, uint32_t blockSize)
 Converts the elements of the Q7 vector to reordered Q15 vector without left-shift. More...
 
+

Description

+

Perform data type conversion in-between neural network operations

+

Function Documentation

+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + +
void arm_q7_to_q15_no_shift (const q7_t * pSrc,
q15_t * pDst,
uint32_t blockSize 
)
+
+
Parameters
+ + + + +
[in]*pSrcpoints to the Q7 input vector
[out]*pDstpoints to the Q15 output vector
[in]blockSizelength of the input vector
+
+
+
Returns
none.
+
Description:
+

The equation used for the conversion process is:

+
    
+        pDst[n] = (q15_t) pSrc[n];   0 <= n < blockSize.    
+
+

Referenced by arm_avepool_q7_HWC(), arm_convolve_HWC_q7_basic(), and arm_convolve_HWC_q7_basic_nonsquare().

+ +
+
+ +
+
+ + + + + + + + + + + + + + + + + + + + + + + + +
void arm_q7_to_q15_reordered_no_shift (const q7_t * pSrc,
q15_t * pDst,
uint32_t blockSize 
)
+
+
Parameters
+ + + + +
[in]*pSrcpoints to the Q7 input vector
[out]*pDstpoints to the Q15 output vector
[in]blockSizelength of the input vector
+
+
+
Returns
none.
+

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.

+ +

Referenced by arm_convolve_1x1_HWC_q7_fast_nonsquare(), arm_convolve_HWC_q7_fast(), arm_convolve_HWC_q7_fast_nonsquare(), arm_fully_connected_q7(), and arm_fully_connected_q7_opt().

+ +
+
+
+
+ + + + diff --git a/docs/NN/html/group__nndata__convert.js b/docs/NN/html/group__nndata__convert.js new file mode 100644 index 0000000..901ae84 --- /dev/null +++ b/docs/NN/html/group__nndata__convert.js @@ -0,0 +1,5 @@ +var group__nndata__convert = +[ + [ "arm_q7_to_q15_no_shift", "group__nndata__convert.html#gae349de4dba8d253c89d45794ccf05680", null ], + [ "arm_q7_to_q15_reordered_no_shift", "group__nndata__convert.html#gaba8fd446d5f54760b406ee63b25d1aee", null ] +]; \ No newline at end of file diff --git a/docs/NN/html/gru_2readme_8txt.html b/docs/NN/html/gru_2readme_8txt.html new file mode 100644 index 0000000..ef527ac --- /dev/null +++ b/docs/NN/html/gru_2readme_8txt.html @@ -0,0 +1,129 @@ + + + + + +readme.txt File Reference +CMSIS-NN: readme.txt File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ + + + + + diff --git a/docs/NN/html/history_8txt.html b/docs/NN/html/history_8txt.html new file mode 100644 index 0000000..749f351 --- /dev/null +++ b/docs/NN/html/history_8txt.html @@ -0,0 +1,129 @@ + + + + + +history.txt File Reference +CMSIS-NN: history.txt File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ + + + + + diff --git a/docs/NN/html/index.html b/docs/NN/html/index.html new file mode 100644 index 0000000..965e6d3 --- /dev/null +++ b/docs/NN/html/index.html @@ -0,0 +1,163 @@ + + + + + +CMSIS NN Software Library +CMSIS-NN: CMSIS NN Software Library + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
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

+
+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

+
+
+ + + + diff --git a/docs/NN/html/jquery.js b/docs/NN/html/jquery.js new file mode 100644 index 0000000..3db33e6 --- /dev/null +++ b/docs/NN/html/jquery.js @@ -0,0 +1,72 @@ +/*! + * jQuery JavaScript Library v1.7.1 + * http://jquery.com/ + * + * Copyright 2011, John Resig + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * Includes Sizzle.js + * http://sizzlejs.com/ + * Copyright 2011, The Dojo Foundation + * Released under the MIT, BSD, and GPL Licenses. + * + * Date: Mon Nov 21 21:11:03 2011 -0500 + */ +(function(bb,L){var av=bb.document,bu=bb.navigator,bl=bb.location;var b=(function(){var bF=function(b0,b1){return new bF.fn.init(b0,b1,bD)},bU=bb.jQuery,bH=bb.$,bD,bY=/^(?:[^#<]*(<[\w\W]+>)[^>]*$|#([\w\-]*)$)/,bM=/\S/,bI=/^\s+/,bE=/\s+$/,bA=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,bN=/^[\],:{}\s]*$/,bW=/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,bP=/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,bJ=/(?:^|:|,)(?:\s*\[)+/g,by=/(webkit)[ \/]([\w.]+)/,bR=/(opera)(?:.*version)?[ \/]([\w.]+)/,bQ=/(msie) ([\w.]+)/,bS=/(mozilla)(?:.*? rv:([\w.]+))?/,bB=/-([a-z]|[0-9])/ig,bZ=/^-ms-/,bT=function(b0,b1){return(b1+"").toUpperCase()},bX=bu.userAgent,bV,bC,e,bL=Object.prototype.toString,bG=Object.prototype.hasOwnProperty,bz=Array.prototype.push,bK=Array.prototype.slice,bO=String.prototype.trim,bv=Array.prototype.indexOf,bx={};bF.fn=bF.prototype={constructor:bF,init:function(b0,b4,b3){var b2,b5,b1,b6;if(!b0){return this}if(b0.nodeType){this.context=this[0]=b0;this.length=1;return this}if(b0==="body"&&!b4&&av.body){this.context=av;this[0]=av.body;this.selector=b0;this.length=1;return this}if(typeof b0==="string"){if(b0.charAt(0)==="<"&&b0.charAt(b0.length-1)===">"&&b0.length>=3){b2=[null,b0,null]}else{b2=bY.exec(b0)}if(b2&&(b2[1]||!b4)){if(b2[1]){b4=b4 instanceof bF?b4[0]:b4;b6=(b4?b4.ownerDocument||b4:av);b1=bA.exec(b0);if(b1){if(bF.isPlainObject(b4)){b0=[av.createElement(b1[1])];bF.fn.attr.call(b0,b4,true)}else{b0=[b6.createElement(b1[1])]}}else{b1=bF.buildFragment([b2[1]],[b6]);b0=(b1.cacheable?bF.clone(b1.fragment):b1.fragment).childNodes}return bF.merge(this,b0)}else{b5=av.getElementById(b2[2]);if(b5&&b5.parentNode){if(b5.id!==b2[2]){return b3.find(b0)}this.length=1;this[0]=b5}this.context=av;this.selector=b0;return this}}else{if(!b4||b4.jquery){return(b4||b3).find(b0)}else{return this.constructor(b4).find(b0)}}}else{if(bF.isFunction(b0)){return b3.ready(b0)}}if(b0.selector!==L){this.selector=b0.selector;this.context=b0.context}return bF.makeArray(b0,this)},selector:"",jquery:"1.7.1",length:0,size:function(){return this.length},toArray:function(){return bK.call(this,0)},get:function(b0){return b0==null?this.toArray():(b0<0?this[this.length+b0]:this[b0])},pushStack:function(b1,b3,b0){var b2=this.constructor();if(bF.isArray(b1)){bz.apply(b2,b1)}else{bF.merge(b2,b1)}b2.prevObject=this;b2.context=this.context;if(b3==="find"){b2.selector=this.selector+(this.selector?" ":"")+b0}else{if(b3){b2.selector=this.selector+"."+b3+"("+b0+")"}}return b2},each:function(b1,b0){return bF.each(this,b1,b0)},ready:function(b0){bF.bindReady();bC.add(b0);return this},eq:function(b0){b0=+b0;return b0===-1?this.slice(b0):this.slice(b0,b0+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(bK.apply(this,arguments),"slice",bK.call(arguments).join(","))},map:function(b0){return this.pushStack(bF.map(this,function(b2,b1){return b0.call(b2,b1,b2)}))},end:function(){return this.prevObject||this.constructor(null)},push:bz,sort:[].sort,splice:[].splice};bF.fn.init.prototype=bF.fn;bF.extend=bF.fn.extend=function(){var b9,b2,b0,b1,b6,b7,b5=arguments[0]||{},b4=1,b3=arguments.length,b8=false;if(typeof b5==="boolean"){b8=b5;b5=arguments[1]||{};b4=2}if(typeof b5!=="object"&&!bF.isFunction(b5)){b5={}}if(b3===b4){b5=this;--b4}for(;b40){return}bC.fireWith(av,[bF]);if(bF.fn.trigger){bF(av).trigger("ready").off("ready")}}},bindReady:function(){if(bC){return}bC=bF.Callbacks("once memory");if(av.readyState==="complete"){return setTimeout(bF.ready,1)}if(av.addEventListener){av.addEventListener("DOMContentLoaded",e,false);bb.addEventListener("load",bF.ready,false)}else{if(av.attachEvent){av.attachEvent("onreadystatechange",e);bb.attachEvent("onload",bF.ready);var b0=false;try{b0=bb.frameElement==null}catch(b1){}if(av.documentElement.doScroll&&b0){bw()}}}},isFunction:function(b0){return bF.type(b0)==="function"},isArray:Array.isArray||function(b0){return bF.type(b0)==="array"},isWindow:function(b0){return b0&&typeof b0==="object"&&"setInterval" in b0},isNumeric:function(b0){return !isNaN(parseFloat(b0))&&isFinite(b0)},type:function(b0){return b0==null?String(b0):bx[bL.call(b0)]||"object"},isPlainObject:function(b2){if(!b2||bF.type(b2)!=="object"||b2.nodeType||bF.isWindow(b2)){return false}try{if(b2.constructor&&!bG.call(b2,"constructor")&&!bG.call(b2.constructor.prototype,"isPrototypeOf")){return false}}catch(b1){return false}var b0;for(b0 in b2){}return b0===L||bG.call(b2,b0)},isEmptyObject:function(b1){for(var b0 in b1){return false}return true},error:function(b0){throw new Error(b0)},parseJSON:function(b0){if(typeof b0!=="string"||!b0){return null}b0=bF.trim(b0);if(bb.JSON&&bb.JSON.parse){return bb.JSON.parse(b0)}if(bN.test(b0.replace(bW,"@").replace(bP,"]").replace(bJ,""))){return(new Function("return "+b0))()}bF.error("Invalid JSON: "+b0)},parseXML:function(b2){var b0,b1;try{if(bb.DOMParser){b1=new DOMParser();b0=b1.parseFromString(b2,"text/xml")}else{b0=new ActiveXObject("Microsoft.XMLDOM");b0.async="false";b0.loadXML(b2)}}catch(b3){b0=L}if(!b0||!b0.documentElement||b0.getElementsByTagName("parsererror").length){bF.error("Invalid XML: "+b2)}return b0},noop:function(){},globalEval:function(b0){if(b0&&bM.test(b0)){(bb.execScript||function(b1){bb["eval"].call(bb,b1)})(b0)}},camelCase:function(b0){return b0.replace(bZ,"ms-").replace(bB,bT)},nodeName:function(b1,b0){return b1.nodeName&&b1.nodeName.toUpperCase()===b0.toUpperCase()},each:function(b3,b6,b2){var b1,b4=0,b5=b3.length,b0=b5===L||bF.isFunction(b3);if(b2){if(b0){for(b1 in b3){if(b6.apply(b3[b1],b2)===false){break}}}else{for(;b40&&b0[0]&&b0[b1-1])||b1===0||bF.isArray(b0));if(b3){for(;b21?aJ.call(arguments,0):bG;if(!(--bw)){bC.resolveWith(bC,bx)}}}function bz(bF){return function(bG){bB[bF]=arguments.length>1?aJ.call(arguments,0):bG;bC.notifyWith(bE,bB)}}if(e>1){for(;bv
a";bI=bv.getElementsByTagName("*");bF=bv.getElementsByTagName("a")[0];if(!bI||!bI.length||!bF){return{}}bG=av.createElement("select");bx=bG.appendChild(av.createElement("option"));bE=bv.getElementsByTagName("input")[0];bJ={leadingWhitespace:(bv.firstChild.nodeType===3),tbody:!bv.getElementsByTagName("tbody").length,htmlSerialize:!!bv.getElementsByTagName("link").length,style:/top/.test(bF.getAttribute("style")),hrefNormalized:(bF.getAttribute("href")==="/a"),opacity:/^0.55/.test(bF.style.opacity),cssFloat:!!bF.style.cssFloat,checkOn:(bE.value==="on"),optSelected:bx.selected,getSetAttribute:bv.className!=="t",enctype:!!av.createElement("form").enctype,html5Clone:av.createElement("nav").cloneNode(true).outerHTML!=="<:nav>",submitBubbles:true,changeBubbles:true,focusinBubbles:false,deleteExpando:true,noCloneEvent:true,inlineBlockNeedsLayout:false,shrinkWrapBlocks:false,reliableMarginRight:true};bE.checked=true;bJ.noCloneChecked=bE.cloneNode(true).checked;bG.disabled=true;bJ.optDisabled=!bx.disabled;try{delete bv.test}catch(bC){bJ.deleteExpando=false}if(!bv.addEventListener&&bv.attachEvent&&bv.fireEvent){bv.attachEvent("onclick",function(){bJ.noCloneEvent=false});bv.cloneNode(true).fireEvent("onclick")}bE=av.createElement("input");bE.value="t";bE.setAttribute("type","radio");bJ.radioValue=bE.value==="t";bE.setAttribute("checked","checked");bv.appendChild(bE);bD=av.createDocumentFragment();bD.appendChild(bv.lastChild);bJ.checkClone=bD.cloneNode(true).cloneNode(true).lastChild.checked;bJ.appendChecked=bE.checked;bD.removeChild(bE);bD.appendChild(bv);bv.innerHTML="";if(bb.getComputedStyle){bA=av.createElement("div");bA.style.width="0";bA.style.marginRight="0";bv.style.width="2px";bv.appendChild(bA);bJ.reliableMarginRight=(parseInt((bb.getComputedStyle(bA,null)||{marginRight:0}).marginRight,10)||0)===0}if(bv.attachEvent){for(by in {submit:1,change:1,focusin:1}){bB="on"+by;bw=(bB in bv);if(!bw){bv.setAttribute(bB,"return;");bw=(typeof bv[bB]==="function")}bJ[by+"Bubbles"]=bw}}bD.removeChild(bv);bD=bG=bx=bA=bv=bE=null;b(function(){var bM,bU,bV,bT,bN,bO,bL,bS,bR,e,bP,bQ=av.getElementsByTagName("body")[0];if(!bQ){return}bL=1;bS="position:absolute;top:0;left:0;width:1px;height:1px;margin:0;";bR="visibility:hidden;border:0;";e="style='"+bS+"border:5px solid #000;padding:0;'";bP="
";bM=av.createElement("div");bM.style.cssText=bR+"width:0;height:0;position:static;top:0;margin-top:"+bL+"px";bQ.insertBefore(bM,bQ.firstChild);bv=av.createElement("div");bM.appendChild(bv);bv.innerHTML="
t
";bz=bv.getElementsByTagName("td");bw=(bz[0].offsetHeight===0);bz[0].style.display="";bz[1].style.display="none";bJ.reliableHiddenOffsets=bw&&(bz[0].offsetHeight===0);bv.innerHTML="";bv.style.width=bv.style.paddingLeft="1px";b.boxModel=bJ.boxModel=bv.offsetWidth===2;if(typeof bv.style.zoom!=="undefined"){bv.style.display="inline";bv.style.zoom=1;bJ.inlineBlockNeedsLayout=(bv.offsetWidth===2);bv.style.display="";bv.innerHTML="
";bJ.shrinkWrapBlocks=(bv.offsetWidth!==2)}bv.style.cssText=bS+bR;bv.innerHTML=bP;bU=bv.firstChild;bV=bU.firstChild;bN=bU.nextSibling.firstChild.firstChild;bO={doesNotAddBorder:(bV.offsetTop!==5),doesAddBorderForTableAndCells:(bN.offsetTop===5)};bV.style.position="fixed";bV.style.top="20px";bO.fixedPosition=(bV.offsetTop===20||bV.offsetTop===15);bV.style.position=bV.style.top="";bU.style.overflow="hidden";bU.style.position="relative";bO.subtractsBorderForOverflowNotVisible=(bV.offsetTop===-5);bO.doesNotIncludeMarginInBodyOffset=(bQ.offsetTop!==bL);bQ.removeChild(bM);bv=bM=null;b.extend(bJ,bO)});return bJ})();var aS=/^(?:\{.*\}|\[.*\])$/,aA=/([A-Z])/g;b.extend({cache:{},uuid:0,expando:"jQuery"+(b.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:true,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:true},hasData:function(e){e=e.nodeType?b.cache[e[b.expando]]:e[b.expando];return !!e&&!S(e)},data:function(bx,bv,bz,by){if(!b.acceptData(bx)){return}var bG,bA,bD,bE=b.expando,bC=typeof bv==="string",bF=bx.nodeType,e=bF?b.cache:bx,bw=bF?bx[bE]:bx[bE]&&bE,bB=bv==="events";if((!bw||!e[bw]||(!bB&&!by&&!e[bw].data))&&bC&&bz===L){return}if(!bw){if(bF){bx[bE]=bw=++b.uuid}else{bw=bE}}if(!e[bw]){e[bw]={};if(!bF){e[bw].toJSON=b.noop}}if(typeof bv==="object"||typeof bv==="function"){if(by){e[bw]=b.extend(e[bw],bv)}else{e[bw].data=b.extend(e[bw].data,bv)}}bG=bA=e[bw];if(!by){if(!bA.data){bA.data={}}bA=bA.data}if(bz!==L){bA[b.camelCase(bv)]=bz}if(bB&&!bA[bv]){return bG.events}if(bC){bD=bA[bv];if(bD==null){bD=bA[b.camelCase(bv)]}}else{bD=bA}return bD},removeData:function(bx,bv,by){if(!b.acceptData(bx)){return}var bB,bA,bz,bC=b.expando,bD=bx.nodeType,e=bD?b.cache:bx,bw=bD?bx[bC]:bC;if(!e[bw]){return}if(bv){bB=by?e[bw]:e[bw].data;if(bB){if(!b.isArray(bv)){if(bv in bB){bv=[bv]}else{bv=b.camelCase(bv);if(bv in bB){bv=[bv]}else{bv=bv.split(" ")}}}for(bA=0,bz=bv.length;bA-1){return true}}return false},val:function(bx){var e,bv,by,bw=this[0];if(!arguments.length){if(bw){e=b.valHooks[bw.nodeName.toLowerCase()]||b.valHooks[bw.type];if(e&&"get" in e&&(bv=e.get(bw,"value"))!==L){return bv}bv=bw.value;return typeof bv==="string"?bv.replace(aU,""):bv==null?"":bv}return}by=b.isFunction(bx);return this.each(function(bA){var bz=b(this),bB;if(this.nodeType!==1){return}if(by){bB=bx.call(this,bA,bz.val())}else{bB=bx}if(bB==null){bB=""}else{if(typeof bB==="number"){bB+=""}else{if(b.isArray(bB)){bB=b.map(bB,function(bC){return bC==null?"":bC+""})}}}e=b.valHooks[this.nodeName.toLowerCase()]||b.valHooks[this.type];if(!e||!("set" in e)||e.set(this,bB,"value")===L){this.value=bB}})}});b.extend({valHooks:{option:{get:function(e){var bv=e.attributes.value;return !bv||bv.specified?e.value:e.text}},select:{get:function(e){var bA,bv,bz,bx,by=e.selectedIndex,bB=[],bC=e.options,bw=e.type==="select-one";if(by<0){return null}bv=bw?by:0;bz=bw?by+1:bC.length;for(;bv=0});if(!e.length){bv.selectedIndex=-1}return e}}},attrFn:{val:true,css:true,html:true,text:true,data:true,width:true,height:true,offset:true},attr:function(bA,bx,bB,bz){var bw,e,by,bv=bA.nodeType; +if(!bA||bv===3||bv===8||bv===2){return}if(bz&&bx in b.attrFn){return b(bA)[bx](bB)}if(typeof bA.getAttribute==="undefined"){return b.prop(bA,bx,bB)}by=bv!==1||!b.isXMLDoc(bA);if(by){bx=bx.toLowerCase();e=b.attrHooks[bx]||(ao.test(bx)?aY:be)}if(bB!==L){if(bB===null){b.removeAttr(bA,bx);return}else{if(e&&"set" in e&&by&&(bw=e.set(bA,bB,bx))!==L){return bw}else{bA.setAttribute(bx,""+bB);return bB}}}else{if(e&&"get" in e&&by&&(bw=e.get(bA,bx))!==null){return bw}else{bw=bA.getAttribute(bx);return bw===null?L:bw}}},removeAttr:function(bx,bz){var by,bA,bv,e,bw=0;if(bz&&bx.nodeType===1){bA=bz.toLowerCase().split(af);e=bA.length;for(;bw=0)}}})});var bd=/^(?:textarea|input|select)$/i,n=/^([^\.]*)?(?:\.(.+))?$/,J=/\bhover(\.\S+)?\b/,aO=/^key/,bf=/^(?:mouse|contextmenu)|click/,T=/^(?:focusinfocus|focusoutblur)$/,U=/^(\w*)(?:#([\w\-]+))?(?:\.([\w\-]+))?$/,Y=function(e){var bv=U.exec(e);if(bv){bv[1]=(bv[1]||"").toLowerCase();bv[3]=bv[3]&&new RegExp("(?:^|\\s)"+bv[3]+"(?:\\s|$)")}return bv},j=function(bw,e){var bv=bw.attributes||{};return((!e[1]||bw.nodeName.toLowerCase()===e[1])&&(!e[2]||(bv.id||{}).value===e[2])&&(!e[3]||e[3].test((bv["class"]||{}).value)))},bt=function(e){return b.event.special.hover?e:e.replace(J,"mouseenter$1 mouseleave$1")};b.event={add:function(bx,bC,bJ,bA,by){var bD,bB,bK,bI,bH,bF,e,bG,bv,bz,bw,bE;if(bx.nodeType===3||bx.nodeType===8||!bC||!bJ||!(bD=b._data(bx))){return}if(bJ.handler){bv=bJ;bJ=bv.handler}if(!bJ.guid){bJ.guid=b.guid++}bK=bD.events;if(!bK){bD.events=bK={}}bB=bD.handle;if(!bB){bD.handle=bB=function(bL){return typeof b!=="undefined"&&(!bL||b.event.triggered!==bL.type)?b.event.dispatch.apply(bB.elem,arguments):L};bB.elem=bx}bC=b.trim(bt(bC)).split(" ");for(bI=0;bI=0){bG=bG.slice(0,-1);bw=true}if(bG.indexOf(".")>=0){bx=bG.split(".");bG=bx.shift();bx.sort()}if((!bA||b.event.customEvent[bG])&&!b.event.global[bG]){return}bv=typeof bv==="object"?bv[b.expando]?bv:new b.Event(bG,bv):new b.Event(bG);bv.type=bG;bv.isTrigger=true;bv.exclusive=bw;bv.namespace=bx.join(".");bv.namespace_re=bv.namespace?new RegExp("(^|\\.)"+bx.join("\\.(?:.*\\.)?")+"(\\.|$)"):null;by=bG.indexOf(":")<0?"on"+bG:"";if(!bA){e=b.cache;for(bC in e){if(e[bC].events&&e[bC].events[bG]){b.event.trigger(bv,bD,e[bC].handle.elem,true)}}return}bv.result=L;if(!bv.target){bv.target=bA}bD=bD!=null?b.makeArray(bD):[];bD.unshift(bv);bF=b.event.special[bG]||{};if(bF.trigger&&bF.trigger.apply(bA,bD)===false){return}bB=[[bA,bF.bindType||bG]];if(!bJ&&!bF.noBubble&&!b.isWindow(bA)){bI=bF.delegateType||bG;bH=T.test(bI+bG)?bA:bA.parentNode;bz=null;for(;bH;bH=bH.parentNode){bB.push([bH,bI]);bz=bH}if(bz&&bz===bA.ownerDocument){bB.push([bz.defaultView||bz.parentWindow||bb,bI])}}for(bC=0;bCbA){bH.push({elem:this,matches:bz.slice(bA)})}for(bC=0;bC0?this.on(e,null,bx,bw):this.trigger(e)};if(b.attrFn){b.attrFn[e]=true}if(aO.test(e)){b.event.fixHooks[e]=b.event.keyHooks}if(bf.test(e)){b.event.fixHooks[e]=b.event.mouseHooks}}); +/*! + * Sizzle CSS Selector Engine + * Copyright 2011, The Dojo Foundation + * Released under the MIT, BSD, and GPL Licenses. + * More information: http://sizzlejs.com/ + */ +(function(){var bH=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^\[\]]*\]|['"][^'"]*['"]|[^\[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,bC="sizcache"+(Math.random()+"").replace(".",""),bI=0,bL=Object.prototype.toString,bB=false,bA=true,bK=/\\/g,bO=/\r\n/g,bQ=/\W/;[0,0].sort(function(){bA=false;return 0});var by=function(bV,e,bY,bZ){bY=bY||[];e=e||av;var b1=e;if(e.nodeType!==1&&e.nodeType!==9){return[]}if(!bV||typeof bV!=="string"){return bY}var bS,b3,b6,bR,b2,b5,b4,bX,bU=true,bT=by.isXML(e),bW=[],b0=bV;do{bH.exec("");bS=bH.exec(b0);if(bS){b0=bS[3];bW.push(bS[1]);if(bS[2]){bR=bS[3];break}}}while(bS);if(bW.length>1&&bD.exec(bV)){if(bW.length===2&&bE.relative[bW[0]]){b3=bM(bW[0]+bW[1],e,bZ)}else{b3=bE.relative[bW[0]]?[e]:by(bW.shift(),e);while(bW.length){bV=bW.shift();if(bE.relative[bV]){bV+=bW.shift()}b3=bM(bV,b3,bZ)}}}else{if(!bZ&&bW.length>1&&e.nodeType===9&&!bT&&bE.match.ID.test(bW[0])&&!bE.match.ID.test(bW[bW.length-1])){b2=by.find(bW.shift(),e,bT);e=b2.expr?by.filter(b2.expr,b2.set)[0]:b2.set[0]}if(e){b2=bZ?{expr:bW.pop(),set:bF(bZ)}:by.find(bW.pop(),bW.length===1&&(bW[0]==="~"||bW[0]==="+")&&e.parentNode?e.parentNode:e,bT);b3=b2.expr?by.filter(b2.expr,b2.set):b2.set;if(bW.length>0){b6=bF(b3)}else{bU=false}while(bW.length){b5=bW.pop();b4=b5;if(!bE.relative[b5]){b5=""}else{b4=bW.pop()}if(b4==null){b4=e}bE.relative[b5](b6,b4,bT)}}else{b6=bW=[]}}if(!b6){b6=b3}if(!b6){by.error(b5||bV)}if(bL.call(b6)==="[object Array]"){if(!bU){bY.push.apply(bY,b6)}else{if(e&&e.nodeType===1){for(bX=0;b6[bX]!=null;bX++){if(b6[bX]&&(b6[bX]===true||b6[bX].nodeType===1&&by.contains(e,b6[bX]))){bY.push(b3[bX])}}}else{for(bX=0;b6[bX]!=null;bX++){if(b6[bX]&&b6[bX].nodeType===1){bY.push(b3[bX])}}}}}else{bF(b6,bY)}if(bR){by(bR,b1,bY,bZ);by.uniqueSort(bY)}return bY};by.uniqueSort=function(bR){if(bJ){bB=bA;bR.sort(bJ);if(bB){for(var e=1;e0};by.find=function(bX,e,bY){var bW,bS,bU,bT,bV,bR;if(!bX){return[]}for(bS=0,bU=bE.order.length;bS":function(bW,bR){var bV,bU=typeof bR==="string",bS=0,e=bW.length;if(bU&&!bQ.test(bR)){bR=bR.toLowerCase();for(;bS=0)){if(!bS){e.push(bV)}}else{if(bS){bR[bU]=false}}}}return false},ID:function(e){return e[1].replace(bK,"")},TAG:function(bR,e){return bR[1].replace(bK,"").toLowerCase()},CHILD:function(e){if(e[1]==="nth"){if(!e[2]){by.error(e[0])}e[2]=e[2].replace(/^\+|\s*/g,"");var bR=/(-?)(\d*)(?:n([+\-]?\d*))?/.exec(e[2]==="even"&&"2n"||e[2]==="odd"&&"2n+1"||!/\D/.test(e[2])&&"0n+"+e[2]||e[2]);e[2]=(bR[1]+(bR[2]||1))-0;e[3]=bR[3]-0}else{if(e[2]){by.error(e[0])}}e[0]=bI++;return e},ATTR:function(bU,bR,bS,e,bV,bW){var bT=bU[1]=bU[1].replace(bK,"");if(!bW&&bE.attrMap[bT]){bU[1]=bE.attrMap[bT]}bU[4]=(bU[4]||bU[5]||"").replace(bK,"");if(bU[2]==="~="){bU[4]=" "+bU[4]+" "}return bU},PSEUDO:function(bU,bR,bS,e,bV){if(bU[1]==="not"){if((bH.exec(bU[3])||"").length>1||/^\w/.test(bU[3])){bU[3]=by(bU[3],null,null,bR)}else{var bT=by.filter(bU[3],bR,bS,true^bV);if(!bS){e.push.apply(e,bT)}return false}}else{if(bE.match.POS.test(bU[0])||bE.match.CHILD.test(bU[0])){return true}}return bU},POS:function(e){e.unshift(true);return e}},filters:{enabled:function(e){return e.disabled===false&&e.type!=="hidden"},disabled:function(e){return e.disabled===true},checked:function(e){return e.checked===true},selected:function(e){if(e.parentNode){e.parentNode.selectedIndex}return e.selected===true},parent:function(e){return !!e.firstChild},empty:function(e){return !e.firstChild},has:function(bS,bR,e){return !!by(e[3],bS).length},header:function(e){return(/h\d/i).test(e.nodeName)},text:function(bS){var e=bS.getAttribute("type"),bR=bS.type;return bS.nodeName.toLowerCase()==="input"&&"text"===bR&&(e===bR||e===null)},radio:function(e){return e.nodeName.toLowerCase()==="input"&&"radio"===e.type},checkbox:function(e){return e.nodeName.toLowerCase()==="input"&&"checkbox"===e.type},file:function(e){return e.nodeName.toLowerCase()==="input"&&"file"===e.type},password:function(e){return e.nodeName.toLowerCase()==="input"&&"password"===e.type},submit:function(bR){var e=bR.nodeName.toLowerCase();return(e==="input"||e==="button")&&"submit"===bR.type},image:function(e){return e.nodeName.toLowerCase()==="input"&&"image"===e.type},reset:function(bR){var e=bR.nodeName.toLowerCase();return(e==="input"||e==="button")&&"reset"===bR.type},button:function(bR){var e=bR.nodeName.toLowerCase();return e==="input"&&"button"===bR.type||e==="button"},input:function(e){return(/input|select|textarea|button/i).test(e.nodeName)},focus:function(e){return e===e.ownerDocument.activeElement}},setFilters:{first:function(bR,e){return e===0},last:function(bS,bR,e,bT){return bR===bT.length-1},even:function(bR,e){return e%2===0},odd:function(bR,e){return e%2===1 +},lt:function(bS,bR,e){return bRe[3]-0},nth:function(bS,bR,e){return e[3]-0===bR},eq:function(bS,bR,e){return e[3]-0===bR}},filter:{PSEUDO:function(bS,bX,bW,bY){var e=bX[1],bR=bE.filters[e];if(bR){return bR(bS,bW,bX,bY)}else{if(e==="contains"){return(bS.textContent||bS.innerText||bw([bS])||"").indexOf(bX[3])>=0}else{if(e==="not"){var bT=bX[3];for(var bV=0,bU=bT.length;bV=0)}}},ID:function(bR,e){return bR.nodeType===1&&bR.getAttribute("id")===e},TAG:function(bR,e){return(e==="*"&&bR.nodeType===1)||!!bR.nodeName&&bR.nodeName.toLowerCase()===e},CLASS:function(bR,e){return(" "+(bR.className||bR.getAttribute("class"))+" ").indexOf(e)>-1},ATTR:function(bV,bT){var bS=bT[1],e=by.attr?by.attr(bV,bS):bE.attrHandle[bS]?bE.attrHandle[bS](bV):bV[bS]!=null?bV[bS]:bV.getAttribute(bS),bW=e+"",bU=bT[2],bR=bT[4];return e==null?bU==="!=":!bU&&by.attr?e!=null:bU==="="?bW===bR:bU==="*="?bW.indexOf(bR)>=0:bU==="~="?(" "+bW+" ").indexOf(bR)>=0:!bR?bW&&e!==false:bU==="!="?bW!==bR:bU==="^="?bW.indexOf(bR)===0:bU==="$="?bW.substr(bW.length-bR.length)===bR:bU==="|="?bW===bR||bW.substr(0,bR.length+1)===bR+"-":false},POS:function(bU,bR,bS,bV){var e=bR[2],bT=bE.setFilters[e];if(bT){return bT(bU,bS,bR,bV)}}}};var bD=bE.match.POS,bx=function(bR,e){return"\\"+(e-0+1)};for(var bz in bE.match){bE.match[bz]=new RegExp(bE.match[bz].source+(/(?![^\[]*\])(?![^\(]*\))/.source));bE.leftMatch[bz]=new RegExp(/(^(?:.|\r|\n)*?)/.source+bE.match[bz].source.replace(/\\(\d+)/g,bx))}var bF=function(bR,e){bR=Array.prototype.slice.call(bR,0);if(e){e.push.apply(e,bR);return e}return bR};try{Array.prototype.slice.call(av.documentElement.childNodes,0)[0].nodeType}catch(bP){bF=function(bU,bT){var bS=0,bR=bT||[];if(bL.call(bU)==="[object Array]"){Array.prototype.push.apply(bR,bU)}else{if(typeof bU.length==="number"){for(var e=bU.length;bS";e.insertBefore(bR,e.firstChild);if(av.getElementById(bS)){bE.find.ID=function(bU,bV,bW){if(typeof bV.getElementById!=="undefined"&&!bW){var bT=bV.getElementById(bU[1]);return bT?bT.id===bU[1]||typeof bT.getAttributeNode!=="undefined"&&bT.getAttributeNode("id").nodeValue===bU[1]?[bT]:L:[]}};bE.filter.ID=function(bV,bT){var bU=typeof bV.getAttributeNode!=="undefined"&&bV.getAttributeNode("id");return bV.nodeType===1&&bU&&bU.nodeValue===bT}}e.removeChild(bR);e=bR=null})();(function(){var e=av.createElement("div");e.appendChild(av.createComment(""));if(e.getElementsByTagName("*").length>0){bE.find.TAG=function(bR,bV){var bU=bV.getElementsByTagName(bR[1]);if(bR[1]==="*"){var bT=[];for(var bS=0;bU[bS];bS++){if(bU[bS].nodeType===1){bT.push(bU[bS])}}bU=bT}return bU}}e.innerHTML="";if(e.firstChild&&typeof e.firstChild.getAttribute!=="undefined"&&e.firstChild.getAttribute("href")!=="#"){bE.attrHandle.href=function(bR){return bR.getAttribute("href",2)}}e=null})();if(av.querySelectorAll){(function(){var e=by,bT=av.createElement("div"),bS="__sizzle__";bT.innerHTML="

";if(bT.querySelectorAll&&bT.querySelectorAll(".TEST").length===0){return}by=function(b4,bV,bZ,b3){bV=bV||av;if(!b3&&!by.isXML(bV)){var b2=/^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec(b4);if(b2&&(bV.nodeType===1||bV.nodeType===9)){if(b2[1]){return bF(bV.getElementsByTagName(b4),bZ)}else{if(b2[2]&&bE.find.CLASS&&bV.getElementsByClassName){return bF(bV.getElementsByClassName(b2[2]),bZ)}}}if(bV.nodeType===9){if(b4==="body"&&bV.body){return bF([bV.body],bZ)}else{if(b2&&b2[3]){var bY=bV.getElementById(b2[3]);if(bY&&bY.parentNode){if(bY.id===b2[3]){return bF([bY],bZ)}}else{return bF([],bZ)}}}try{return bF(bV.querySelectorAll(b4),bZ)}catch(b0){}}else{if(bV.nodeType===1&&bV.nodeName.toLowerCase()!=="object"){var bW=bV,bX=bV.getAttribute("id"),bU=bX||bS,b6=bV.parentNode,b5=/^\s*[+~]/.test(b4);if(!bX){bV.setAttribute("id",bU)}else{bU=bU.replace(/'/g,"\\$&")}if(b5&&b6){bV=bV.parentNode}try{if(!b5||b6){return bF(bV.querySelectorAll("[id='"+bU+"'] "+b4),bZ)}}catch(b1){}finally{if(!bX){bW.removeAttribute("id")}}}}}return e(b4,bV,bZ,b3)};for(var bR in e){by[bR]=e[bR]}bT=null})()}(function(){var e=av.documentElement,bS=e.matchesSelector||e.mozMatchesSelector||e.webkitMatchesSelector||e.msMatchesSelector;if(bS){var bU=!bS.call(av.createElement("div"),"div"),bR=false;try{bS.call(av.documentElement,"[test!='']:sizzle")}catch(bT){bR=true}by.matchesSelector=function(bW,bY){bY=bY.replace(/\=\s*([^'"\]]*)\s*\]/g,"='$1']");if(!by.isXML(bW)){try{if(bR||!bE.match.PSEUDO.test(bY)&&!/!=/.test(bY)){var bV=bS.call(bW,bY);if(bV||!bU||bW.document&&bW.document.nodeType!==11){return bV}}}catch(bX){}}return by(bY,null,null,[bW]).length>0}}})();(function(){var e=av.createElement("div");e.innerHTML="
";if(!e.getElementsByClassName||e.getElementsByClassName("e").length===0){return}e.lastChild.className="e";if(e.getElementsByClassName("e").length===1){return}bE.order.splice(1,0,"CLASS");bE.find.CLASS=function(bR,bS,bT){if(typeof bS.getElementsByClassName!=="undefined"&&!bT){return bS.getElementsByClassName(bR[1])}};e=null})();function bv(bR,bW,bV,bZ,bX,bY){for(var bT=0,bS=bZ.length;bT0){bU=e;break}}}e=e[bR]}bZ[bT]=bU}}}if(av.documentElement.contains){by.contains=function(bR,e){return bR!==e&&(bR.contains?bR.contains(e):true)}}else{if(av.documentElement.compareDocumentPosition){by.contains=function(bR,e){return !!(bR.compareDocumentPosition(e)&16)}}else{by.contains=function(){return false}}}by.isXML=function(e){var bR=(e?e.ownerDocument||e:0).documentElement;return bR?bR.nodeName!=="HTML":false};var bM=function(bS,e,bW){var bV,bX=[],bU="",bY=e.nodeType?[e]:e;while((bV=bE.match.PSEUDO.exec(bS))){bU+=bV[0];bS=bS.replace(bE.match.PSEUDO,"")}bS=bE.relative[bS]?bS+"*":bS;for(var bT=0,bR=bY.length;bT0){for(bB=bA;bB=0:b.filter(e,this).length>0:this.filter(e).length>0)},closest:function(by,bx){var bv=[],bw,e,bz=this[0];if(b.isArray(by)){var bB=1;while(bz&&bz.ownerDocument&&bz!==bx){for(bw=0;bw-1:b.find.matchesSelector(bz,by)){bv.push(bz);break}else{bz=bz.parentNode;if(!bz||!bz.ownerDocument||bz===bx||bz.nodeType===11){break}}}}bv=bv.length>1?b.unique(bv):bv;return this.pushStack(bv,"closest",by)},index:function(e){if(!e){return(this[0]&&this[0].parentNode)?this.prevAll().length:-1}if(typeof e==="string"){return b.inArray(this[0],b(e))}return b.inArray(e.jquery?e[0]:e,this)},add:function(e,bv){var bx=typeof e==="string"?b(e,bv):b.makeArray(e&&e.nodeType?[e]:e),bw=b.merge(this.get(),bx);return this.pushStack(C(bx[0])||C(bw[0])?bw:b.unique(bw))},andSelf:function(){return this.add(this.prevObject)}});function C(e){return !e||!e.parentNode||e.parentNode.nodeType===11}b.each({parent:function(bv){var e=bv.parentNode;return e&&e.nodeType!==11?e:null},parents:function(e){return b.dir(e,"parentNode")},parentsUntil:function(bv,e,bw){return b.dir(bv,"parentNode",bw)},next:function(e){return b.nth(e,2,"nextSibling")},prev:function(e){return b.nth(e,2,"previousSibling")},nextAll:function(e){return b.dir(e,"nextSibling")},prevAll:function(e){return b.dir(e,"previousSibling")},nextUntil:function(bv,e,bw){return b.dir(bv,"nextSibling",bw)},prevUntil:function(bv,e,bw){return b.dir(bv,"previousSibling",bw)},siblings:function(e){return b.sibling(e.parentNode.firstChild,e)},children:function(e){return b.sibling(e.firstChild)},contents:function(e){return b.nodeName(e,"iframe")?e.contentDocument||e.contentWindow.document:b.makeArray(e.childNodes)}},function(e,bv){b.fn[e]=function(by,bw){var bx=b.map(this,bv,by);if(!ab.test(e)){bw=by}if(bw&&typeof bw==="string"){bx=b.filter(bw,bx)}bx=this.length>1&&!ay[e]?b.unique(bx):bx;if((this.length>1||a9.test(bw))&&aq.test(e)){bx=bx.reverse()}return this.pushStack(bx,e,P.call(arguments).join(","))}});b.extend({filter:function(bw,e,bv){if(bv){bw=":not("+bw+")"}return e.length===1?b.find.matchesSelector(e[0],bw)?[e[0]]:[]:b.find.matches(bw,e)},dir:function(bw,bv,by){var e=[],bx=bw[bv];while(bx&&bx.nodeType!==9&&(by===L||bx.nodeType!==1||!b(bx).is(by))){if(bx.nodeType===1){e.push(bx)}bx=bx[bv]}return e},nth:function(by,e,bw,bx){e=e||1;var bv=0;for(;by;by=by[bw]){if(by.nodeType===1&&++bv===e){break}}return by},sibling:function(bw,bv){var e=[];for(;bw;bw=bw.nextSibling){if(bw.nodeType===1&&bw!==bv){e.push(bw)}}return e}});function aG(bx,bw,e){bw=bw||0;if(b.isFunction(bw)){return b.grep(bx,function(bz,by){var bA=!!bw.call(bz,by,bz);return bA===e})}else{if(bw.nodeType){return b.grep(bx,function(bz,by){return(bz===bw)===e})}else{if(typeof bw==="string"){var bv=b.grep(bx,function(by){return by.nodeType===1});if(bp.test(bw)){return b.filter(bw,bv,!e)}else{bw=b.filter(bw,bv)}}}}return b.grep(bx,function(bz,by){return(b.inArray(bz,bw)>=0)===e})}function a(e){var bw=aR.split("|"),bv=e.createDocumentFragment();if(bv.createElement){while(bw.length){bv.createElement(bw.pop())}}return bv}var aR="abbr|article|aside|audio|canvas|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",ag=/ jQuery\d+="(?:\d+|null)"/g,ar=/^\s+/,R=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,d=/<([\w:]+)/,w=/",""],legend:[1,"
","
"],thead:[1,"","
"],tr:[2,"","
"],td:[3,"","
"],col:[2,"","
"],area:[1,"",""],_default:[0,"",""]},ac=a(av); +ax.optgroup=ax.option;ax.tbody=ax.tfoot=ax.colgroup=ax.caption=ax.thead;ax.th=ax.td;if(!b.support.htmlSerialize){ax._default=[1,"div
","
"]}b.fn.extend({text:function(e){if(b.isFunction(e)){return this.each(function(bw){var bv=b(this);bv.text(e.call(this,bw,bv.text()))})}if(typeof e!=="object"&&e!==L){return this.empty().append((this[0]&&this[0].ownerDocument||av).createTextNode(e))}return b.text(this)},wrapAll:function(e){if(b.isFunction(e)){return this.each(function(bw){b(this).wrapAll(e.call(this,bw))})}if(this[0]){var bv=b(e,this[0].ownerDocument).eq(0).clone(true);if(this[0].parentNode){bv.insertBefore(this[0])}bv.map(function(){var bw=this;while(bw.firstChild&&bw.firstChild.nodeType===1){bw=bw.firstChild}return bw}).append(this)}return this},wrapInner:function(e){if(b.isFunction(e)){return this.each(function(bv){b(this).wrapInner(e.call(this,bv))})}return this.each(function(){var bv=b(this),bw=bv.contents();if(bw.length){bw.wrapAll(e)}else{bv.append(e)}})},wrap:function(e){var bv=b.isFunction(e);return this.each(function(bw){b(this).wrapAll(bv?e.call(this,bw):e)})},unwrap:function(){return this.parent().each(function(){if(!b.nodeName(this,"body")){b(this).replaceWith(this.childNodes)}}).end()},append:function(){return this.domManip(arguments,true,function(e){if(this.nodeType===1){this.appendChild(e)}})},prepend:function(){return this.domManip(arguments,true,function(e){if(this.nodeType===1){this.insertBefore(e,this.firstChild)}})},before:function(){if(this[0]&&this[0].parentNode){return this.domManip(arguments,false,function(bv){this.parentNode.insertBefore(bv,this)})}else{if(arguments.length){var e=b.clean(arguments);e.push.apply(e,this.toArray());return this.pushStack(e,"before",arguments)}}},after:function(){if(this[0]&&this[0].parentNode){return this.domManip(arguments,false,function(bv){this.parentNode.insertBefore(bv,this.nextSibling)})}else{if(arguments.length){var e=this.pushStack(this,"after",arguments);e.push.apply(e,b.clean(arguments));return e}}},remove:function(e,bx){for(var bv=0,bw;(bw=this[bv])!=null;bv++){if(!e||b.filter(e,[bw]).length){if(!bx&&bw.nodeType===1){b.cleanData(bw.getElementsByTagName("*"));b.cleanData([bw])}if(bw.parentNode){bw.parentNode.removeChild(bw)}}}return this},empty:function(){for(var e=0,bv;(bv=this[e])!=null;e++){if(bv.nodeType===1){b.cleanData(bv.getElementsByTagName("*"))}while(bv.firstChild){bv.removeChild(bv.firstChild)}}return this},clone:function(bv,e){bv=bv==null?false:bv;e=e==null?bv:e;return this.map(function(){return b.clone(this,bv,e)})},html:function(bx){if(bx===L){return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(ag,""):null}else{if(typeof bx==="string"&&!ae.test(bx)&&(b.support.leadingWhitespace||!ar.test(bx))&&!ax[(d.exec(bx)||["",""])[1].toLowerCase()]){bx=bx.replace(R,"<$1>");try{for(var bw=0,bv=this.length;bw1&&bw0?this.clone(true):this).get();b(bC[bA])[bv](by);bz=bz.concat(by)}return this.pushStack(bz,e,bC.selector)}}});function bg(e){if(typeof e.getElementsByTagName!=="undefined"){return e.getElementsByTagName("*")}else{if(typeof e.querySelectorAll!=="undefined"){return e.querySelectorAll("*")}else{return[]}}}function az(e){if(e.type==="checkbox"||e.type==="radio"){e.defaultChecked=e.checked}}function E(e){var bv=(e.nodeName||"").toLowerCase();if(bv==="input"){az(e)}else{if(bv!=="script"&&typeof e.getElementsByTagName!=="undefined"){b.grep(e.getElementsByTagName("input"),az)}}}function al(e){var bv=av.createElement("div");ac.appendChild(bv);bv.innerHTML=e.outerHTML;return bv.firstChild}b.extend({clone:function(by,bA,bw){var e,bv,bx,bz=b.support.html5Clone||!ah.test("<"+by.nodeName)?by.cloneNode(true):al(by);if((!b.support.noCloneEvent||!b.support.noCloneChecked)&&(by.nodeType===1||by.nodeType===11)&&!b.isXMLDoc(by)){ai(by,bz);e=bg(by);bv=bg(bz);for(bx=0;e[bx];++bx){if(bv[bx]){ai(e[bx],bv[bx])}}}if(bA){t(by,bz);if(bw){e=bg(by);bv=bg(bz);for(bx=0;e[bx];++bx){t(e[bx],bv[bx])}}}e=bv=null;return bz},clean:function(bw,by,bH,bA){var bF;by=by||av;if(typeof by.createElement==="undefined"){by=by.ownerDocument||by[0]&&by[0].ownerDocument||av}var bI=[],bB;for(var bE=0,bz;(bz=bw[bE])!=null;bE++){if(typeof bz==="number"){bz+=""}if(!bz){continue}if(typeof bz==="string"){if(!W.test(bz)){bz=by.createTextNode(bz)}else{bz=bz.replace(R,"<$1>");var bK=(d.exec(bz)||["",""])[1].toLowerCase(),bx=ax[bK]||ax._default,bD=bx[0],bv=by.createElement("div");if(by===av){ac.appendChild(bv)}else{a(by).appendChild(bv)}bv.innerHTML=bx[1]+bz+bx[2];while(bD--){bv=bv.lastChild}if(!b.support.tbody){var e=w.test(bz),bC=bK==="table"&&!e?bv.firstChild&&bv.firstChild.childNodes:bx[1]===""&&!e?bv.childNodes:[];for(bB=bC.length-1;bB>=0;--bB){if(b.nodeName(bC[bB],"tbody")&&!bC[bB].childNodes.length){bC[bB].parentNode.removeChild(bC[bB])}}}if(!b.support.leadingWhitespace&&ar.test(bz)){bv.insertBefore(by.createTextNode(ar.exec(bz)[0]),bv.firstChild)}bz=bv.childNodes}}var bG;if(!b.support.appendChecked){if(bz[0]&&typeof(bG=bz.length)==="number"){for(bB=0;bB=0){return bx+"px"}}else{return bx}}}});if(!b.support.opacity){b.cssHooks.opacity={get:function(bv,e){return au.test((e&&bv.currentStyle?bv.currentStyle.filter:bv.style.filter)||"")?(parseFloat(RegExp.$1)/100)+"":e?"1":""},set:function(by,bz){var bx=by.style,bv=by.currentStyle,e=b.isNumeric(bz)?"alpha(opacity="+bz*100+")":"",bw=bv&&bv.filter||bx.filter||"";bx.zoom=1;if(bz>=1&&b.trim(bw.replace(ak,""))===""){bx.removeAttribute("filter");if(bv&&!bv.filter){return}}bx.filter=ak.test(bw)?bw.replace(ak,e):bw+" "+e}}}b(function(){if(!b.support.reliableMarginRight){b.cssHooks.marginRight={get:function(bw,bv){var e;b.swap(bw,{display:"inline-block"},function(){if(bv){e=Z(bw,"margin-right","marginRight")}else{e=bw.style.marginRight}});return e}}}});if(av.defaultView&&av.defaultView.getComputedStyle){aI=function(by,bw){var bv,bx,e;bw=bw.replace(z,"-$1").toLowerCase();if((bx=by.ownerDocument.defaultView)&&(e=bx.getComputedStyle(by,null))){bv=e.getPropertyValue(bw);if(bv===""&&!b.contains(by.ownerDocument.documentElement,by)){bv=b.style(by,bw)}}return bv}}if(av.documentElement.currentStyle){aX=function(bz,bw){var bA,e,by,bv=bz.currentStyle&&bz.currentStyle[bw],bx=bz.style;if(bv===null&&bx&&(by=bx[bw])){bv=by}if(!bc.test(bv)&&bn.test(bv)){bA=bx.left;e=bz.runtimeStyle&&bz.runtimeStyle.left;if(e){bz.runtimeStyle.left=bz.currentStyle.left}bx.left=bw==="fontSize"?"1em":(bv||0);bv=bx.pixelLeft+"px";bx.left=bA;if(e){bz.runtimeStyle.left=e}}return bv===""?"auto":bv}}Z=aI||aX;function p(by,bw,bv){var bA=bw==="width"?by.offsetWidth:by.offsetHeight,bz=bw==="width"?an:a1,bx=0,e=bz.length; +if(bA>0){if(bv!=="border"){for(;bx)<[^<]*)*<\/script>/gi,q=/^(?:select|textarea)/i,h=/\s+/,br=/([?&])_=[^&]*/,K=/^([\w\+\.\-]+:)(?:\/\/([^\/?#:]*)(?::(\d+))?)?/,A=b.fn.load,aa={},r={},aE,s,aV=["*/"]+["*"];try{aE=bl.href}catch(aw){aE=av.createElement("a");aE.href="";aE=aE.href}s=K.exec(aE.toLowerCase())||[];function f(e){return function(by,bA){if(typeof by!=="string"){bA=by;by="*"}if(b.isFunction(bA)){var bx=by.toLowerCase().split(h),bw=0,bz=bx.length,bv,bB,bC;for(;bw=0){var e=bw.slice(by,bw.length);bw=bw.slice(0,by)}var bx="GET";if(bz){if(b.isFunction(bz)){bA=bz;bz=L}else{if(typeof bz==="object"){bz=b.param(bz,b.ajaxSettings.traditional);bx="POST"}}}var bv=this;b.ajax({url:bw,type:bx,dataType:"html",data:bz,complete:function(bC,bB,bD){bD=bC.responseText;if(bC.isResolved()){bC.done(function(bE){bD=bE});bv.html(e?b("
").append(bD.replace(a6,"")).find(e):bD)}if(bA){bv.each(bA,[bD,bB,bC])}}});return this},serialize:function(){return b.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?b.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||q.test(this.nodeName)||aZ.test(this.type))}).map(function(e,bv){var bw=b(this).val();return bw==null?null:b.isArray(bw)?b.map(bw,function(by,bx){return{name:bv.name,value:by.replace(bs,"\r\n")}}):{name:bv.name,value:bw.replace(bs,"\r\n")}}).get()}});b.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(e,bv){b.fn[bv]=function(bw){return this.on(bv,bw)}});b.each(["get","post"],function(e,bv){b[bv]=function(bw,by,bz,bx){if(b.isFunction(by)){bx=bx||bz;bz=by;by=L}return b.ajax({type:bv,url:bw,data:by,success:bz,dataType:bx})}});b.extend({getScript:function(e,bv){return b.get(e,L,bv,"script")},getJSON:function(e,bv,bw){return b.get(e,bv,bw,"json")},ajaxSetup:function(bv,e){if(e){am(bv,b.ajaxSettings)}else{e=bv;bv=b.ajaxSettings}am(bv,e);return bv},ajaxSettings:{url:aE,isLocal:aM.test(s[1]),global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,accepts:{xml:"application/xml, text/xml",html:"text/html",text:"text/plain",json:"application/json, text/javascript","*":aV},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText"},converters:{"* text":bb.String,"text html":true,"text json":b.parseJSON,"text xml":b.parseXML},flatOptions:{context:true,url:true}},ajaxPrefilter:f(aa),ajaxTransport:f(r),ajax:function(bz,bx){if(typeof bz==="object"){bx=bz;bz=L}bx=bx||{};var bD=b.ajaxSetup({},bx),bS=bD.context||bD,bG=bS!==bD&&(bS.nodeType||bS instanceof b)?b(bS):b.event,bR=b.Deferred(),bN=b.Callbacks("once memory"),bB=bD.statusCode||{},bC,bH={},bO={},bQ,by,bL,bE,bI,bA=0,bw,bK,bJ={readyState:0,setRequestHeader:function(bT,bU){if(!bA){var e=bT.toLowerCase();bT=bO[e]=bO[e]||bT;bH[bT]=bU}return this},getAllResponseHeaders:function(){return bA===2?bQ:null},getResponseHeader:function(bT){var e;if(bA===2){if(!by){by={};while((e=aD.exec(bQ))){by[e[1].toLowerCase()]=e[2]}}e=by[bT.toLowerCase()]}return e===L?null:e},overrideMimeType:function(e){if(!bA){bD.mimeType=e}return this},abort:function(e){e=e||"abort";if(bL){bL.abort(e)}bF(0,e);return this}};function bF(bZ,bU,b0,bW){if(bA===2){return}bA=2;if(bE){clearTimeout(bE)}bL=L;bQ=bW||"";bJ.readyState=bZ>0?4:0;var bT,b4,b3,bX=bU,bY=b0?bj(bD,bJ,b0):L,bV,b2;if(bZ>=200&&bZ<300||bZ===304){if(bD.ifModified){if((bV=bJ.getResponseHeader("Last-Modified"))){b.lastModified[bC]=bV}if((b2=bJ.getResponseHeader("Etag"))){b.etag[bC]=b2}}if(bZ===304){bX="notmodified";bT=true}else{try{b4=G(bD,bY);bX="success";bT=true}catch(b1){bX="parsererror";b3=b1}}}else{b3=bX;if(!bX||bZ){bX="error";if(bZ<0){bZ=0}}}bJ.status=bZ;bJ.statusText=""+(bU||bX);if(bT){bR.resolveWith(bS,[b4,bX,bJ])}else{bR.rejectWith(bS,[bJ,bX,b3])}bJ.statusCode(bB);bB=L;if(bw){bG.trigger("ajax"+(bT?"Success":"Error"),[bJ,bD,bT?b4:b3])}bN.fireWith(bS,[bJ,bX]);if(bw){bG.trigger("ajaxComplete",[bJ,bD]);if(!(--b.active)){b.event.trigger("ajaxStop")}}}bR.promise(bJ);bJ.success=bJ.done;bJ.error=bJ.fail;bJ.complete=bN.add;bJ.statusCode=function(bT){if(bT){var e;if(bA<2){for(e in bT){bB[e]=[bB[e],bT[e]]}}else{e=bT[bJ.status];bJ.then(e,e)}}return this};bD.url=((bz||bD.url)+"").replace(bq,"").replace(c,s[1]+"//");bD.dataTypes=b.trim(bD.dataType||"*").toLowerCase().split(h);if(bD.crossDomain==null){bI=K.exec(bD.url.toLowerCase());bD.crossDomain=!!(bI&&(bI[1]!=s[1]||bI[2]!=s[2]||(bI[3]||(bI[1]==="http:"?80:443))!=(s[3]||(s[1]==="http:"?80:443))))}if(bD.data&&bD.processData&&typeof bD.data!=="string"){bD.data=b.param(bD.data,bD.traditional)}aW(aa,bD,bx,bJ);if(bA===2){return false}bw=bD.global;bD.type=bD.type.toUpperCase();bD.hasContent=!aQ.test(bD.type);if(bw&&b.active++===0){b.event.trigger("ajaxStart")}if(!bD.hasContent){if(bD.data){bD.url+=(M.test(bD.url)?"&":"?")+bD.data;delete bD.data}bC=bD.url;if(bD.cache===false){var bv=b.now(),bP=bD.url.replace(br,"$1_="+bv);bD.url=bP+((bP===bD.url)?(M.test(bD.url)?"&":"?")+"_="+bv:"")}}if(bD.data&&bD.hasContent&&bD.contentType!==false||bx.contentType){bJ.setRequestHeader("Content-Type",bD.contentType)}if(bD.ifModified){bC=bC||bD.url;if(b.lastModified[bC]){bJ.setRequestHeader("If-Modified-Since",b.lastModified[bC])}if(b.etag[bC]){bJ.setRequestHeader("If-None-Match",b.etag[bC])}}bJ.setRequestHeader("Accept",bD.dataTypes[0]&&bD.accepts[bD.dataTypes[0]]?bD.accepts[bD.dataTypes[0]]+(bD.dataTypes[0]!=="*"?", "+aV+"; q=0.01":""):bD.accepts["*"]);for(bK in bD.headers){bJ.setRequestHeader(bK,bD.headers[bK])}if(bD.beforeSend&&(bD.beforeSend.call(bS,bJ,bD)===false||bA===2)){bJ.abort();return false}for(bK in {success:1,error:1,complete:1}){bJ[bK](bD[bK])}bL=aW(r,bD,bx,bJ);if(!bL){bF(-1,"No Transport")}else{bJ.readyState=1;if(bw){bG.trigger("ajaxSend",[bJ,bD])}if(bD.async&&bD.timeout>0){bE=setTimeout(function(){bJ.abort("timeout")},bD.timeout)}try{bA=1;bL.send(bH,bF)}catch(bM){if(bA<2){bF(-1,bM)}else{throw bM}}}return bJ},param:function(e,bw){var bv=[],by=function(bz,bA){bA=b.isFunction(bA)?bA():bA;bv[bv.length]=encodeURIComponent(bz)+"="+encodeURIComponent(bA)};if(bw===L){bw=b.ajaxSettings.traditional}if(b.isArray(e)||(e.jquery&&!b.isPlainObject(e))){b.each(e,function(){by(this.name,this.value)})}else{for(var bx in e){v(bx,e[bx],bw,by)}}return bv.join("&").replace(k,"+")}});function v(bw,by,bv,bx){if(b.isArray(by)){b.each(by,function(bA,bz){if(bv||ap.test(bw)){bx(bw,bz)}else{v(bw+"["+(typeof bz==="object"||b.isArray(bz)?bA:"")+"]",bz,bv,bx)}})}else{if(!bv&&by!=null&&typeof by==="object"){for(var e in by){v(bw+"["+e+"]",by[e],bv,bx)}}else{bx(bw,by)}}}b.extend({active:0,lastModified:{},etag:{}});function bj(bD,bC,bz){var bv=bD.contents,bB=bD.dataTypes,bw=bD.responseFields,by,bA,bx,e;for(bA in bw){if(bA in bz){bC[bw[bA]]=bz[bA]}}while(bB[0]==="*"){bB.shift();if(by===L){by=bD.mimeType||bC.getResponseHeader("content-type")}}if(by){for(bA in bv){if(bv[bA]&&bv[bA].test(by)){bB.unshift(bA);break}}}if(bB[0] in bz){bx=bB[0]}else{for(bA in bz){if(!bB[0]||bD.converters[bA+" "+bB[0]]){bx=bA;break}if(!e){e=bA}}bx=bx||e}if(bx){if(bx!==bB[0]){bB.unshift(bx)}return bz[bx]}}function G(bH,bz){if(bH.dataFilter){bz=bH.dataFilter(bz,bH.dataType)}var bD=bH.dataTypes,bG={},bA,bE,bw=bD.length,bB,bC=bD[0],bx,by,bF,bv,e;for(bA=1;bA=bw.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();bw.animatedProperties[this.prop]=true;for(bA in bw.animatedProperties){if(bw.animatedProperties[bA]!==true){e=false}}if(e){if(bw.overflow!=null&&!b.support.shrinkWrapBlocks){b.each(["","X","Y"],function(bC,bD){bz.style["overflow"+bD]=bw.overflow[bC]})}if(bw.hide){b(bz).hide()}if(bw.hide||bw.show){for(bA in bw.animatedProperties){b.style(bz,bA,bw.orig[bA]);b.removeData(bz,"fxshow"+bA,true);b.removeData(bz,"toggle"+bA,true)}}bv=bw.complete;if(bv){bw.complete=false;bv.call(bz)}}return false}else{if(bw.duration==Infinity){this.now=bx}else{bB=bx-this.startTime;this.state=bB/bw.duration;this.pos=b.easing[bw.animatedProperties[this.prop]](this.state,bB,0,1,bw.duration);this.now=this.start+((this.end-this.start)*this.pos)}this.update()}return true}};b.extend(b.fx,{tick:function(){var bw,bv=b.timers,e=0;for(;e").appendTo(e),bw=bv.css("display");bv.remove();if(bw==="none"||bw===""){if(!a8){a8=av.createElement("iframe");a8.frameBorder=a8.width=a8.height=0}e.appendChild(a8);if(!m||!a8.createElement){m=(a8.contentWindow||a8.contentDocument).document;m.write((av.compatMode==="CSS1Compat"?"":"")+"");m.close()}bv=m.createElement(bx);m.body.appendChild(bv);bw=b.css(bv,"display");e.removeChild(a8)}Q[bx]=bw}return Q[bx]}var V=/^t(?:able|d|h)$/i,ad=/^(?:body|html)$/i;if("getBoundingClientRect" in av.documentElement){b.fn.offset=function(bI){var by=this[0],bB;if(bI){return this.each(function(e){b.offset.setOffset(this,bI,e)})}if(!by||!by.ownerDocument){return null}if(by===by.ownerDocument.body){return b.offset.bodyOffset(by)}try{bB=by.getBoundingClientRect()}catch(bF){}var bH=by.ownerDocument,bw=bH.documentElement;if(!bB||!b.contains(bw,by)){return bB?{top:bB.top,left:bB.left}:{top:0,left:0}}var bC=bH.body,bD=aK(bH),bA=bw.clientTop||bC.clientTop||0,bE=bw.clientLeft||bC.clientLeft||0,bv=bD.pageYOffset||b.support.boxModel&&bw.scrollTop||bC.scrollTop,bz=bD.pageXOffset||b.support.boxModel&&bw.scrollLeft||bC.scrollLeft,bG=bB.top+bv-bA,bx=bB.left+bz-bE;return{top:bG,left:bx}}}else{b.fn.offset=function(bF){var bz=this[0];if(bF){return this.each(function(bG){b.offset.setOffset(this,bF,bG)})}if(!bz||!bz.ownerDocument){return null}if(bz===bz.ownerDocument.body){return b.offset.bodyOffset(bz)}var bC,bw=bz.offsetParent,bv=bz,bE=bz.ownerDocument,bx=bE.documentElement,bA=bE.body,bB=bE.defaultView,e=bB?bB.getComputedStyle(bz,null):bz.currentStyle,bD=bz.offsetTop,by=bz.offsetLeft;while((bz=bz.parentNode)&&bz!==bA&&bz!==bx){if(b.support.fixedPosition&&e.position==="fixed"){break}bC=bB?bB.getComputedStyle(bz,null):bz.currentStyle;bD-=bz.scrollTop;by-=bz.scrollLeft;if(bz===bw){bD+=bz.offsetTop;by+=bz.offsetLeft;if(b.support.doesNotAddBorder&&!(b.support.doesAddBorderForTableAndCells&&V.test(bz.nodeName))){bD+=parseFloat(bC.borderTopWidth)||0;by+=parseFloat(bC.borderLeftWidth)||0}bv=bw;bw=bz.offsetParent}if(b.support.subtractsBorderForOverflowNotVisible&&bC.overflow!=="visible"){bD+=parseFloat(bC.borderTopWidth)||0;by+=parseFloat(bC.borderLeftWidth)||0}e=bC}if(e.position==="relative"||e.position==="static"){bD+=bA.offsetTop;by+=bA.offsetLeft}if(b.support.fixedPosition&&e.position==="fixed"){bD+=Math.max(bx.scrollTop,bA.scrollTop);by+=Math.max(bx.scrollLeft,bA.scrollLeft)}return{top:bD,left:by}}}b.offset={bodyOffset:function(e){var bw=e.offsetTop,bv=e.offsetLeft;if(b.support.doesNotIncludeMarginInBodyOffset){bw+=parseFloat(b.css(e,"marginTop"))||0;bv+=parseFloat(b.css(e,"marginLeft"))||0}return{top:bw,left:bv}},setOffset:function(bx,bG,bA){var bB=b.css(bx,"position");if(bB==="static"){bx.style.position="relative"}var bz=b(bx),bv=bz.offset(),e=b.css(bx,"top"),bE=b.css(bx,"left"),bF=(bB==="absolute"||bB==="fixed")&&b.inArray("auto",[e,bE])>-1,bD={},bC={},bw,by;if(bF){bC=bz.position();bw=bC.top;by=bC.left}else{bw=parseFloat(e)||0;by=parseFloat(bE)||0}if(b.isFunction(bG)){bG=bG.call(bx,bA,bv)}if(bG.top!=null){bD.top=(bG.top-bv.top)+bw}if(bG.left!=null){bD.left=(bG.left-bv.left)+by}if("using" in bG){bG.using.call(bx,bD)}else{bz.css(bD)}}};b.fn.extend({position:function(){if(!this[0]){return null}var bw=this[0],bv=this.offsetParent(),bx=this.offset(),e=ad.test(bv[0].nodeName)?{top:0,left:0}:bv.offset();bx.top-=parseFloat(b.css(bw,"marginTop"))||0;bx.left-=parseFloat(b.css(bw,"marginLeft"))||0;e.top+=parseFloat(b.css(bv[0],"borderTopWidth"))||0;e.left+=parseFloat(b.css(bv[0],"borderLeftWidth"))||0;return{top:bx.top-e.top,left:bx.left-e.left}},offsetParent:function(){return this.map(function(){var e=this.offsetParent||av.body;while(e&&(!ad.test(e.nodeName)&&b.css(e,"position")==="static")){e=e.offsetParent}return e})}});b.each(["Left","Top"],function(bv,e){var bw="scroll"+e;b.fn[bw]=function(bz){var bx,by;if(bz===L){bx=this[0];if(!bx){return null}by=aK(bx);return by?("pageXOffset" in by)?by[bv?"pageYOffset":"pageXOffset"]:b.support.boxModel&&by.document.documentElement[bw]||by.document.body[bw]:bx[bw]}return this.each(function(){by=aK(this);if(by){by.scrollTo(!bv?bz:b(by).scrollLeft(),bv?bz:b(by).scrollTop())}else{this[bw]=bz}})}});function aK(e){return b.isWindow(e)?e:e.nodeType===9?e.defaultView||e.parentWindow:false}b.each(["Height","Width"],function(bv,e){var bw=e.toLowerCase();b.fn["inner"+e]=function(){var bx=this[0];return bx?bx.style?parseFloat(b.css(bx,bw,"padding")):this[bw]():null};b.fn["outer"+e]=function(by){var bx=this[0];return bx?bx.style?parseFloat(b.css(bx,bw,by?"margin":"border")):this[bw]():null};b.fn[bw]=function(bz){var bA=this[0];if(!bA){return bz==null?null:this}if(b.isFunction(bz)){return this.each(function(bE){var bD=b(this);bD[bw](bz.call(this,bE,bD[bw]()))})}if(b.isWindow(bA)){var bB=bA.document.documentElement["client"+e],bx=bA.document.body;return bA.document.compatMode==="CSS1Compat"&&bB||bx&&bx["client"+e]||bB}else{if(bA.nodeType===9){return Math.max(bA.documentElement["client"+e],bA.body["scroll"+e],bA.documentElement["scroll"+e],bA.body["offset"+e],bA.documentElement["offset"+e])}else{if(bz===L){var bC=b.css(bA,bw),by=parseFloat(bC);return b.isNumeric(by)?by:bC}else{return this.css(bw,typeof bz==="string"?bz:bz+"px")}}}}});bb.jQuery=bb.$=b;if(typeof define==="function"&&define.amd&&define.amd.jQuery){define("jquery",[],function(){return b +})}})(window); +/*! + * jQuery UI 1.8.18 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI + */ +(function(a,d){a.ui=a.ui||{};if(a.ui.version){return}a.extend(a.ui,{version:"1.8.18",keyCode:{ALT:18,BACKSPACE:8,CAPS_LOCK:20,COMMA:188,COMMAND:91,COMMAND_LEFT:91,COMMAND_RIGHT:93,CONTROL:17,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,INSERT:45,LEFT:37,MENU:93,NUMPAD_ADD:107,NUMPAD_DECIMAL:110,NUMPAD_DIVIDE:111,NUMPAD_ENTER:108,NUMPAD_MULTIPLY:106,NUMPAD_SUBTRACT:109,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SHIFT:16,SPACE:32,TAB:9,UP:38,WINDOWS:91}});a.fn.extend({propAttr:a.fn.prop||a.fn.attr,_focus:a.fn.focus,focus:function(e,f){return typeof e==="number"?this.each(function(){var g=this;setTimeout(function(){a(g).focus();if(f){f.call(g)}},e)}):this._focus.apply(this,arguments)},scrollParent:function(){var e;if((a.browser.msie&&(/(static|relative)/).test(this.css("position")))||(/absolute/).test(this.css("position"))){e=this.parents().filter(function(){return(/(relative|absolute|fixed)/).test(a.curCSS(this,"position",1))&&(/(auto|scroll)/).test(a.curCSS(this,"overflow",1)+a.curCSS(this,"overflow-y",1)+a.curCSS(this,"overflow-x",1))}).eq(0)}else{e=this.parents().filter(function(){return(/(auto|scroll)/).test(a.curCSS(this,"overflow",1)+a.curCSS(this,"overflow-y",1)+a.curCSS(this,"overflow-x",1))}).eq(0)}return(/fixed/).test(this.css("position"))||!e.length?a(document):e},zIndex:function(h){if(h!==d){return this.css("zIndex",h)}if(this.length){var f=a(this[0]),e,g;while(f.length&&f[0]!==document){e=f.css("position");if(e==="absolute"||e==="relative"||e==="fixed"){g=parseInt(f.css("zIndex"),10);if(!isNaN(g)&&g!==0){return g}}f=f.parent()}}return 0},disableSelection:function(){return this.bind((a.support.selectstart?"selectstart":"mousedown")+".ui-disableSelection",function(e){e.preventDefault()})},enableSelection:function(){return this.unbind(".ui-disableSelection")}});a.each(["Width","Height"],function(g,e){var f=e==="Width"?["Left","Right"]:["Top","Bottom"],h=e.toLowerCase(),k={innerWidth:a.fn.innerWidth,innerHeight:a.fn.innerHeight,outerWidth:a.fn.outerWidth,outerHeight:a.fn.outerHeight};function j(m,l,i,n){a.each(f,function(){l-=parseFloat(a.curCSS(m,"padding"+this,true))||0;if(i){l-=parseFloat(a.curCSS(m,"border"+this+"Width",true))||0}if(n){l-=parseFloat(a.curCSS(m,"margin"+this,true))||0}});return l}a.fn["inner"+e]=function(i){if(i===d){return k["inner"+e].call(this)}return this.each(function(){a(this).css(h,j(this,i)+"px")})};a.fn["outer"+e]=function(i,l){if(typeof i!=="number"){return k["outer"+e].call(this,i)}return this.each(function(){a(this).css(h,j(this,i,true,l)+"px")})}});function c(g,e){var j=g.nodeName.toLowerCase();if("area"===j){var i=g.parentNode,h=i.name,f;if(!g.href||!h||i.nodeName.toLowerCase()!=="map"){return false}f=a("img[usemap=#"+h+"]")[0];return !!f&&b(f)}return(/input|select|textarea|button|object/.test(j)?!g.disabled:"a"==j?g.href||e:e)&&b(g)}function b(e){return !a(e).parents().andSelf().filter(function(){return a.curCSS(this,"visibility")==="hidden"||a.expr.filters.hidden(this)}).length}a.extend(a.expr[":"],{data:function(g,f,e){return !!a.data(g,e[3])},focusable:function(e){return c(e,!isNaN(a.attr(e,"tabindex")))},tabbable:function(g){var e=a.attr(g,"tabindex"),f=isNaN(e);return(f||e>=0)&&c(g,!f)}});a(function(){var e=document.body,f=e.appendChild(f=document.createElement("div"));f.offsetHeight;a.extend(f.style,{minHeight:"100px",height:"auto",padding:0,borderWidth:0});a.support.minHeight=f.offsetHeight===100;a.support.selectstart="onselectstart" in f;e.removeChild(f).style.display="none"});a.extend(a.ui,{plugin:{add:function(f,g,j){var h=a.ui[f].prototype;for(var e in j){h.plugins[e]=h.plugins[e]||[];h.plugins[e].push([g,j[e]])}},call:function(e,g,f){var j=e.plugins[g];if(!j||!e.element[0].parentNode){return}for(var h=0;h0){return true}h[e]=1;g=(h[e]>0);h[e]=0;return g},isOverAxis:function(f,e,g){return(f>e)&&(f<(e+g))},isOver:function(j,f,i,h,e,g){return a.ui.isOverAxis(j,i,e)&&a.ui.isOverAxis(f,h,g)}})})(jQuery);/*! + * jQuery UI Widget 1.8.18 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Widget + */ +(function(b,d){if(b.cleanData){var c=b.cleanData;b.cleanData=function(f){for(var g=0,h;(h=f[g])!=null;g++){try{b(h).triggerHandler("remove")}catch(j){}}c(f)}}else{var a=b.fn.remove;b.fn.remove=function(e,f){return this.each(function(){if(!f){if(!e||b.filter(e,[this]).length){b("*",this).add([this]).each(function(){try{b(this).triggerHandler("remove")}catch(g){}})}}return a.call(b(this),e,f)})}}b.widget=function(f,h,e){var g=f.split(".")[0],j;f=f.split(".")[1];j=g+"-"+f;if(!e){e=h;h=b.Widget}b.expr[":"][j]=function(k){return !!b.data(k,f)};b[g]=b[g]||{};b[g][f]=function(k,l){if(arguments.length){this._createWidget(k,l)}};var i=new h();i.options=b.extend(true,{},i.options);b[g][f].prototype=b.extend(true,i,{namespace:g,widgetName:f,widgetEventPrefix:b[g][f].prototype.widgetEventPrefix||f,widgetBaseClass:j},e);b.widget.bridge(f,b[g][f])};b.widget.bridge=function(f,e){b.fn[f]=function(i){var g=typeof i==="string",h=Array.prototype.slice.call(arguments,1),j=this;i=!g&&h.length?b.extend.apply(null,[true,i].concat(h)):i;if(g&&i.charAt(0)==="_"){return j}if(g){this.each(function(){var k=b.data(this,f),l=k&&b.isFunction(k[i])?k[i].apply(k,h):k;if(l!==k&&l!==d){j=l;return false}})}else{this.each(function(){var k=b.data(this,f);if(k){k.option(i||{})._init()}else{b.data(this,f,new e(i,this))}})}return j}};b.Widget=function(e,f){if(arguments.length){this._createWidget(e,f)}};b.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",options:{disabled:false},_createWidget:function(f,g){b.data(g,this.widgetName,this);this.element=b(g);this.options=b.extend(true,{},this.options,this._getCreateOptions(),f);var e=this;this.element.bind("remove."+this.widgetName,function(){e.destroy()});this._create();this._trigger("create");this._init()},_getCreateOptions:function(){return b.metadata&&b.metadata.get(this.element[0])[this.widgetName]},_create:function(){},_init:function(){},destroy:function(){this.element.unbind("."+this.widgetName).removeData(this.widgetName);this.widget().unbind("."+this.widgetName).removeAttr("aria-disabled").removeClass(this.widgetBaseClass+"-disabled ui-state-disabled")},widget:function(){return this.element},option:function(f,g){var e=f;if(arguments.length===0){return b.extend({},this.options)}if(typeof f==="string"){if(g===d){return this.options[f]}e={};e[f]=g}this._setOptions(e);return this},_setOptions:function(f){var e=this;b.each(f,function(g,h){e._setOption(g,h)});return this},_setOption:function(e,f){this.options[e]=f;if(e==="disabled"){this.widget()[f?"addClass":"removeClass"](this.widgetBaseClass+"-disabled ui-state-disabled").attr("aria-disabled",f)}return this},enable:function(){return this._setOption("disabled",false)},disable:function(){return this._setOption("disabled",true)},_trigger:function(e,f,g){var j,i,h=this.options[e];g=g||{};f=b.Event(f);f.type=(e===this.widgetEventPrefix?e:this.widgetEventPrefix+e).toLowerCase();f.target=this.element[0];i=f.originalEvent;if(i){for(j in i){if(!(j in f)){f[j]=i[j]}}}this.element.trigger(f,g);return !(b.isFunction(h)&&h.call(this.element[0],f,g)===false||f.isDefaultPrevented())}}})(jQuery);/*! + * jQuery UI Mouse 1.8.18 + * + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * http://docs.jquery.com/UI/Mouse + * + * Depends: + * jquery.ui.widget.js + */ +(function(b,c){var a=false;b(document).mouseup(function(d){a=false});b.widget("ui.mouse",{options:{cancel:":input,option",distance:1,delay:0},_mouseInit:function(){var d=this;this.element.bind("mousedown."+this.widgetName,function(e){return d._mouseDown(e)}).bind("click."+this.widgetName,function(e){if(true===b.data(e.target,d.widgetName+".preventClickEvent")){b.removeData(e.target,d.widgetName+".preventClickEvent");e.stopImmediatePropagation();return false}});this.started=false},_mouseDestroy:function(){this.element.unbind("."+this.widgetName)},_mouseDown:function(f){if(a){return}(this._mouseStarted&&this._mouseUp(f));this._mouseDownEvent=f;var e=this,g=(f.which==1),d=(typeof this.options.cancel=="string"&&f.target.nodeName?b(f.target).closest(this.options.cancel).length:false);if(!g||d||!this._mouseCapture(f)){return true}this.mouseDelayMet=!this.options.delay;if(!this.mouseDelayMet){this._mouseDelayTimer=setTimeout(function(){e.mouseDelayMet=true},this.options.delay)}if(this._mouseDistanceMet(f)&&this._mouseDelayMet(f)){this._mouseStarted=(this._mouseStart(f)!==false);if(!this._mouseStarted){f.preventDefault();return true}}if(true===b.data(f.target,this.widgetName+".preventClickEvent")){b.removeData(f.target,this.widgetName+".preventClickEvent")}this._mouseMoveDelegate=function(h){return e._mouseMove(h)};this._mouseUpDelegate=function(h){return e._mouseUp(h)};b(document).bind("mousemove."+this.widgetName,this._mouseMoveDelegate).bind("mouseup."+this.widgetName,this._mouseUpDelegate);f.preventDefault();a=true;return true},_mouseMove:function(d){if(b.browser.msie&&!(document.documentMode>=9)&&!d.button){return this._mouseUp(d)}if(this._mouseStarted){this._mouseDrag(d);return d.preventDefault()}if(this._mouseDistanceMet(d)&&this._mouseDelayMet(d)){this._mouseStarted=(this._mouseStart(this._mouseDownEvent,d)!==false);(this._mouseStarted?this._mouseDrag(d):this._mouseUp(d))}return !this._mouseStarted},_mouseUp:function(d){b(document).unbind("mousemove."+this.widgetName,this._mouseMoveDelegate).unbind("mouseup."+this.widgetName,this._mouseUpDelegate);if(this._mouseStarted){this._mouseStarted=false;if(d.target==this._mouseDownEvent.target){b.data(d.target,this.widgetName+".preventClickEvent",true)}this._mouseStop(d)}return false},_mouseDistanceMet:function(d){return(Math.max(Math.abs(this._mouseDownEvent.pageX-d.pageX),Math.abs(this._mouseDownEvent.pageY-d.pageY))>=this.options.distance)},_mouseDelayMet:function(d){return this.mouseDelayMet},_mouseStart:function(d){},_mouseDrag:function(d){},_mouseStop:function(d){},_mouseCapture:function(d){return true}})})(jQuery);(function(c,d){c.widget("ui.resizable",c.ui.mouse,{widgetEventPrefix:"resize",options:{alsoResize:false,animate:false,animateDuration:"slow",animateEasing:"swing",aspectRatio:false,autoHide:false,containment:false,ghost:false,grid:false,handles:"e,s,se",helper:false,maxHeight:null,maxWidth:null,minHeight:10,minWidth:10,zIndex:1000},_create:function(){var f=this,k=this.options;this.element.addClass("ui-resizable");c.extend(this,{_aspectRatio:!!(k.aspectRatio),aspectRatio:k.aspectRatio,originalElement:this.element,_proportionallyResizeElements:[],_helper:k.helper||k.ghost||k.animate?k.helper||"ui-resizable-helper":null});if(this.element[0].nodeName.match(/canvas|textarea|input|select|button|img/i)){this.element.wrap(c('
').css({position:this.element.css("position"),width:this.element.outerWidth(),height:this.element.outerHeight(),top:this.element.css("top"),left:this.element.css("left")}));this.element=this.element.parent().data("resizable",this.element.data("resizable"));this.elementIsWrapper=true;this.element.css({marginLeft:this.originalElement.css("marginLeft"),marginTop:this.originalElement.css("marginTop"),marginRight:this.originalElement.css("marginRight"),marginBottom:this.originalElement.css("marginBottom")});this.originalElement.css({marginLeft:0,marginTop:0,marginRight:0,marginBottom:0});this.originalResizeStyle=this.originalElement.css("resize");this.originalElement.css("resize","none");this._proportionallyResizeElements.push(this.originalElement.css({position:"static",zoom:1,display:"block"}));this.originalElement.css({margin:this.originalElement.css("margin")});this._proportionallyResize()}this.handles=k.handles||(!c(".ui-resizable-handle",this.element).length?"e,s,se":{n:".ui-resizable-n",e:".ui-resizable-e",s:".ui-resizable-s",w:".ui-resizable-w",se:".ui-resizable-se",sw:".ui-resizable-sw",ne:".ui-resizable-ne",nw:".ui-resizable-nw"});if(this.handles.constructor==String){if(this.handles=="all"){this.handles="n,e,s,w,se,sw,ne,nw"}var l=this.handles.split(",");this.handles={};for(var g=0;g
');if(/sw|se|ne|nw/.test(j)){h.css({zIndex:++k.zIndex})}if("se"==j){h.addClass("ui-icon ui-icon-gripsmall-diagonal-se")}this.handles[j]=".ui-resizable-"+j;this.element.append(h)}}this._renderAxis=function(q){q=q||this.element;for(var n in this.handles){if(this.handles[n].constructor==String){this.handles[n]=c(this.handles[n],this.element).show()}if(this.elementIsWrapper&&this.originalElement[0].nodeName.match(/textarea|input|select|button/i)){var o=c(this.handles[n],this.element),p=0;p=/sw|ne|nw|se|n|s/.test(n)?o.outerHeight():o.outerWidth();var m=["padding",/ne|nw|n/.test(n)?"Top":/se|sw|s/.test(n)?"Bottom":/^e$/.test(n)?"Right":"Left"].join("");q.css(m,p);this._proportionallyResize()}if(!c(this.handles[n]).length){continue}}};this._renderAxis(this.element);this._handles=c(".ui-resizable-handle",this.element).disableSelection();this._handles.mouseover(function(){if(!f.resizing){if(this.className){var i=this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i)}f.axis=i&&i[1]?i[1]:"se"}});if(k.autoHide){this._handles.hide();c(this.element).addClass("ui-resizable-autohide").hover(function(){if(k.disabled){return}c(this).removeClass("ui-resizable-autohide");f._handles.show()},function(){if(k.disabled){return}if(!f.resizing){c(this).addClass("ui-resizable-autohide");f._handles.hide()}})}this._mouseInit()},destroy:function(){this._mouseDestroy();var e=function(g){c(g).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing").removeData("resizable").unbind(".resizable").find(".ui-resizable-handle").remove()};if(this.elementIsWrapper){e(this.element);var f=this.element;f.after(this.originalElement.css({position:f.css("position"),width:f.outerWidth(),height:f.outerHeight(),top:f.css("top"),left:f.css("left")})).remove()}this.originalElement.css("resize",this.originalResizeStyle);e(this.originalElement);return this},_mouseCapture:function(f){var g=false;for(var e in this.handles){if(c(this.handles[e])[0]==f.target){g=true}}return !this.options.disabled&&g},_mouseStart:function(g){var j=this.options,f=this.element.position(),e=this.element;this.resizing=true;this.documentScroll={top:c(document).scrollTop(),left:c(document).scrollLeft()};if(e.is(".ui-draggable")||(/absolute/).test(e.css("position"))){e.css({position:"absolute",top:f.top,left:f.left})}this._renderProxy();var k=b(this.helper.css("left")),h=b(this.helper.css("top"));if(j.containment){k+=c(j.containment).scrollLeft()||0;h+=c(j.containment).scrollTop()||0}this.offset=this.helper.offset();this.position={left:k,top:h};this.size=this._helper?{width:e.outerWidth(),height:e.outerHeight()}:{width:e.width(),height:e.height()};this.originalSize=this._helper?{width:e.outerWidth(),height:e.outerHeight()}:{width:e.width(),height:e.height()};this.originalPosition={left:k,top:h};this.sizeDiff={width:e.outerWidth()-e.width(),height:e.outerHeight()-e.height()};this.originalMousePosition={left:g.pageX,top:g.pageY};this.aspectRatio=(typeof j.aspectRatio=="number")?j.aspectRatio:((this.originalSize.width/this.originalSize.height)||1);var i=c(".ui-resizable-"+this.axis).css("cursor");c("body").css("cursor",i=="auto"?this.axis+"-resize":i);e.addClass("ui-resizable-resizing");this._propagate("start",g);return true},_mouseDrag:function(e){var h=this.helper,g=this.options,m={},q=this,j=this.originalMousePosition,n=this.axis;var r=(e.pageX-j.left)||0,p=(e.pageY-j.top)||0;var i=this._change[n];if(!i){return false}var l=i.apply(this,[e,r,p]),k=c.browser.msie&&c.browser.version<7,f=this.sizeDiff;this._updateVirtualBoundaries(e.shiftKey);if(this._aspectRatio||e.shiftKey){l=this._updateRatio(l,e)}l=this._respectSize(l,e);this._propagate("resize",e);h.css({top:this.position.top+"px",left:this.position.left+"px",width:this.size.width+"px",height:this.size.height+"px"});if(!this._helper&&this._proportionallyResizeElements.length){this._proportionallyResize()}this._updateCache(l);this._trigger("resize",e,this.ui());return false},_mouseStop:function(h){this.resizing=false;var i=this.options,m=this;if(this._helper){var g=this._proportionallyResizeElements,e=g.length&&(/textarea/i).test(g[0].nodeName),f=e&&c.ui.hasScroll(g[0],"left")?0:m.sizeDiff.height,k=e?0:m.sizeDiff.width;var n={width:(m.helper.width()-k),height:(m.helper.height()-f)},j=(parseInt(m.element.css("left"),10)+(m.position.left-m.originalPosition.left))||null,l=(parseInt(m.element.css("top"),10)+(m.position.top-m.originalPosition.top))||null;if(!i.animate){this.element.css(c.extend(n,{top:l,left:j}))}m.helper.height(m.size.height);m.helper.width(m.size.width);if(this._helper&&!i.animate){this._proportionallyResize()}}c("body").css("cursor","auto");this.element.removeClass("ui-resizable-resizing");this._propagate("stop",h);if(this._helper){this.helper.remove()}return false},_updateVirtualBoundaries:function(g){var j=this.options,i,h,f,k,e;e={minWidth:a(j.minWidth)?j.minWidth:0,maxWidth:a(j.maxWidth)?j.maxWidth:Infinity,minHeight:a(j.minHeight)?j.minHeight:0,maxHeight:a(j.maxHeight)?j.maxHeight:Infinity};if(this._aspectRatio||g){i=e.minHeight*this.aspectRatio;f=e.minWidth/this.aspectRatio;h=e.maxHeight*this.aspectRatio;k=e.maxWidth/this.aspectRatio;if(i>e.minWidth){e.minWidth=i}if(f>e.minHeight){e.minHeight=f}if(hl.width),s=a(l.height)&&i.minHeight&&(i.minHeight>l.height);if(h){l.width=i.minWidth}if(s){l.height=i.minHeight}if(t){l.width=i.maxWidth}if(m){l.height=i.maxHeight}var f=this.originalPosition.left+this.originalSize.width,p=this.position.top+this.size.height;var k=/sw|nw|w/.test(q),e=/nw|ne|n/.test(q);if(h&&k){l.left=f-i.minWidth}if(t&&k){l.left=f-i.maxWidth}if(s&&e){l.top=p-i.minHeight}if(m&&e){l.top=p-i.maxHeight}var n=!l.width&&!l.height;if(n&&!l.left&&l.top){l.top=null}else{if(n&&!l.top&&l.left){l.left=null}}return l},_proportionallyResize:function(){var k=this.options;if(!this._proportionallyResizeElements.length){return}var g=this.helper||this.element;for(var f=0;f');var e=c.browser.msie&&c.browser.version<7,g=(e?1:0),h=(e?2:-1);this.helper.addClass(this._helper).css({width:this.element.outerWidth()+h,height:this.element.outerHeight()+h,position:"absolute",left:this.elementOffset.left-g+"px",top:this.elementOffset.top-g+"px",zIndex:++i.zIndex});this.helper.appendTo("body").disableSelection()}else{this.helper=this.element}},_change:{e:function(g,f,e){return{width:this.originalSize.width+f}},w:function(h,f,e){var j=this.options,g=this.originalSize,i=this.originalPosition;return{left:i.left+f,width:g.width-f}},n:function(h,f,e){var j=this.options,g=this.originalSize,i=this.originalPosition;return{top:i.top+e,height:g.height-e}},s:function(g,f,e){return{height:this.originalSize.height+e}},se:function(g,f,e){return c.extend(this._change.s.apply(this,arguments),this._change.e.apply(this,[g,f,e]))},sw:function(g,f,e){return c.extend(this._change.s.apply(this,arguments),this._change.w.apply(this,[g,f,e]))},ne:function(g,f,e){return c.extend(this._change.n.apply(this,arguments),this._change.e.apply(this,[g,f,e]))},nw:function(g,f,e){return c.extend(this._change.n.apply(this,arguments),this._change.w.apply(this,[g,f,e]))}},_propagate:function(f,e){c.ui.plugin.call(this,f,[e,this.ui()]);(f!="resize"&&this._trigger(f,e,this.ui()))},plugins:{},ui:function(){return{originalElement:this.originalElement,element:this.element,helper:this.helper,position:this.position,size:this.size,originalSize:this.originalSize,originalPosition:this.originalPosition}}});c.extend(c.ui.resizable,{version:"1.8.18"});c.ui.plugin.add("resizable","alsoResize",{start:function(f,g){var e=c(this).data("resizable"),i=e.options;var h=function(j){c(j).each(function(){var k=c(this);k.data("resizable-alsoresize",{width:parseInt(k.width(),10),height:parseInt(k.height(),10),left:parseInt(k.css("left"),10),top:parseInt(k.css("top"),10)})})};if(typeof(i.alsoResize)=="object"&&!i.alsoResize.parentNode){if(i.alsoResize.length){i.alsoResize=i.alsoResize[0];h(i.alsoResize)}else{c.each(i.alsoResize,function(j){h(j)})}}else{h(i.alsoResize)}},resize:function(g,i){var f=c(this).data("resizable"),j=f.options,h=f.originalSize,l=f.originalPosition;var k={height:(f.size.height-h.height)||0,width:(f.size.width-h.width)||0,top:(f.position.top-l.top)||0,left:(f.position.left-l.left)||0},e=function(m,n){c(m).each(function(){var q=c(this),r=c(this).data("resizable-alsoresize"),p={},o=n&&n.length?n:q.parents(i.originalElement[0]).length?["width","height"]:["width","height","top","left"];c.each(o,function(s,u){var t=(r[u]||0)+(k[u]||0);if(t&&t>=0){p[u]=t||null}});q.css(p)})};if(typeof(j.alsoResize)=="object"&&!j.alsoResize.nodeType){c.each(j.alsoResize,function(m,n){e(m,n)})}else{e(j.alsoResize)}},stop:function(e,f){c(this).removeData("resizable-alsoresize")}});c.ui.plugin.add("resizable","animate",{stop:function(i,n){var p=c(this).data("resizable"),j=p.options;var h=p._proportionallyResizeElements,e=h.length&&(/textarea/i).test(h[0].nodeName),f=e&&c.ui.hasScroll(h[0],"left")?0:p.sizeDiff.height,l=e?0:p.sizeDiff.width;var g={width:(p.size.width-l),height:(p.size.height-f)},k=(parseInt(p.element.css("left"),10)+(p.position.left-p.originalPosition.left))||null,m=(parseInt(p.element.css("top"),10)+(p.position.top-p.originalPosition.top))||null; +p.element.animate(c.extend(g,m&&k?{top:m,left:k}:{}),{duration:j.animateDuration,easing:j.animateEasing,step:function(){var o={width:parseInt(p.element.css("width"),10),height:parseInt(p.element.css("height"),10),top:parseInt(p.element.css("top"),10),left:parseInt(p.element.css("left"),10)};if(h&&h.length){c(h[0]).css({width:o.width,height:o.height})}p._updateCache(o);p._propagate("resize",i)}})}});c.ui.plugin.add("resizable","containment",{start:function(f,r){var t=c(this).data("resizable"),j=t.options,l=t.element;var g=j.containment,k=(g instanceof c)?g.get(0):(/parent/.test(g))?l.parent().get(0):g;if(!k){return}t.containerElement=c(k);if(/document/.test(g)||g==document){t.containerOffset={left:0,top:0};t.containerPosition={left:0,top:0};t.parentData={element:c(document),left:0,top:0,width:c(document).width(),height:c(document).height()||document.body.parentNode.scrollHeight}}else{var n=c(k),i=[];c(["Top","Right","Left","Bottom"]).each(function(p,o){i[p]=b(n.css("padding"+o))});t.containerOffset=n.offset();t.containerPosition=n.position();t.containerSize={height:(n.innerHeight()-i[3]),width:(n.innerWidth()-i[1])};var q=t.containerOffset,e=t.containerSize.height,m=t.containerSize.width,h=(c.ui.hasScroll(k,"left")?k.scrollWidth:m),s=(c.ui.hasScroll(k)?k.scrollHeight:e);t.parentData={element:k,left:q.left,top:q.top,width:h,height:s}}},resize:function(g,q){var t=c(this).data("resizable"),i=t.options,f=t.containerSize,p=t.containerOffset,m=t.size,n=t.position,r=t._aspectRatio||g.shiftKey,e={top:0,left:0},h=t.containerElement;if(h[0]!=document&&(/static/).test(h.css("position"))){e=p}if(n.left<(t._helper?p.left:0)){t.size.width=t.size.width+(t._helper?(t.position.left-p.left):(t.position.left-e.left));if(r){t.size.height=t.size.width/i.aspectRatio}t.position.left=i.helper?p.left:0}if(n.top<(t._helper?p.top:0)){t.size.height=t.size.height+(t._helper?(t.position.top-p.top):t.position.top);if(r){t.size.width=t.size.height*i.aspectRatio}t.position.top=t._helper?p.top:0}t.offset.left=t.parentData.left+t.position.left;t.offset.top=t.parentData.top+t.position.top;var l=Math.abs((t._helper?t.offset.left-e.left:(t.offset.left-e.left))+t.sizeDiff.width),s=Math.abs((t._helper?t.offset.top-e.top:(t.offset.top-p.top))+t.sizeDiff.height);var k=t.containerElement.get(0)==t.element.parent().get(0),j=/relative|absolute/.test(t.containerElement.css("position"));if(k&&j){l-=t.parentData.left}if(l+t.size.width>=t.parentData.width){t.size.width=t.parentData.width-l;if(r){t.size.height=t.size.width/t.aspectRatio}}if(s+t.size.height>=t.parentData.height){t.size.height=t.parentData.height-s;if(r){t.size.width=t.size.height*t.aspectRatio}}},stop:function(f,n){var q=c(this).data("resizable"),g=q.options,l=q.position,m=q.containerOffset,e=q.containerPosition,i=q.containerElement;var j=c(q.helper),r=j.offset(),p=j.outerWidth()-q.sizeDiff.width,k=j.outerHeight()-q.sizeDiff.height;if(q._helper&&!g.animate&&(/relative/).test(i.css("position"))){c(this).css({left:r.left-e.left-m.left,width:p,height:k})}if(q._helper&&!g.animate&&(/static/).test(i.css("position"))){c(this).css({left:r.left-e.left-m.left,width:p,height:k})}}});c.ui.plugin.add("resizable","ghost",{start:function(g,h){var e=c(this).data("resizable"),i=e.options,f=e.size;e.ghost=e.originalElement.clone();e.ghost.css({opacity:0.25,display:"block",position:"relative",height:f.height,width:f.width,margin:0,left:0,top:0}).addClass("ui-resizable-ghost").addClass(typeof i.ghost=="string"?i.ghost:"");e.ghost.appendTo(e.helper)},resize:function(f,g){var e=c(this).data("resizable"),h=e.options;if(e.ghost){e.ghost.css({position:"relative",height:e.size.height,width:e.size.width})}},stop:function(f,g){var e=c(this).data("resizable"),h=e.options;if(e.ghost&&e.helper){e.helper.get(0).removeChild(e.ghost.get(0))}}});c.ui.plugin.add("resizable","grid",{resize:function(e,m){var p=c(this).data("resizable"),h=p.options,k=p.size,i=p.originalSize,j=p.originalPosition,n=p.axis,l=h._aspectRatio||e.shiftKey;h.grid=typeof h.grid=="number"?[h.grid,h.grid]:h.grid;var g=Math.round((k.width-i.width)/(h.grid[0]||1))*(h.grid[0]||1),f=Math.round((k.height-i.height)/(h.grid[1]||1))*(h.grid[1]||1);if(/^(se|s|e)$/.test(n)){p.size.width=i.width+g;p.size.height=i.height+f}else{if(/^(ne)$/.test(n)){p.size.width=i.width+g;p.size.height=i.height+f;p.position.top=j.top-f}else{if(/^(sw)$/.test(n)){p.size.width=i.width+g;p.size.height=i.height+f;p.position.left=j.left-g}else{p.size.width=i.width+g;p.size.height=i.height+f;p.position.top=j.top-f;p.position.left=j.left-g}}}}});var b=function(e){return parseInt(e,10)||0};var a=function(e){return !isNaN(parseInt(e,10))}})(jQuery);/*! + * jQuery hashchange event - v1.3 - 7/21/2010 + * http://benalman.com/projects/jquery-hashchange-plugin/ + * + * Copyright (c) 2010 "Cowboy" Ben Alman + * Dual licensed under the MIT and GPL licenses. + * http://benalman.com/about/license/ + */ +(function($,e,b){var c="hashchange",h=document,f,g=$.event.special,i=h.documentMode,d="on"+c in e&&(i===b||i>7);function a(j){j=j||location.href;return"#"+j.replace(/^[^#]*#?(.*)$/,"$1")}$.fn[c]=function(j){return j?this.bind(c,j):this.trigger(c)};$.fn[c].delay=50;g[c]=$.extend(g[c],{setup:function(){if(d){return false}$(f.start)},teardown:function(){if(d){return false}$(f.stop)}});f=(function(){var j={},p,m=a(),k=function(q){return q},l=k,o=k;j.start=function(){p||n()};j.stop=function(){p&&clearTimeout(p);p=b};function n(){var r=a(),q=o(m);if(r!==m){l(m=r,q);$(e).trigger(c)}else{if(q!==m){location.href=location.href.replace(/#.*/,"")+q}}p=setTimeout(n,$.fn[c].delay)}$.browser.msie&&!d&&(function(){var q,r;j.start=function(){if(!q){r=$.fn[c].src;r=r&&r+a();q=$(' + + +
+
+
Reference
+
+
+
Here is a list of all modules:
+
[detail level 12]
+ + + + + + + + + + +
oConvolutional Neural Network Example
oGated Recurrent Unit Example
oNeural Network Functions
|oNeural Network Activation Functions
|oNeural Network Convolution Functions
|oFully-connected Layer Functions
|oNeural Network Pooling Functions
|\Softmax Functions
oNeural Network Data Conversion Functions
\Basic Math Functions for Neural Network Computation
+ + + + + + + diff --git a/docs/NN/html/modules.js b/docs/NN/html/modules.js new file mode 100644 index 0000000..bfe3611 --- /dev/null +++ b/docs/NN/html/modules.js @@ -0,0 +1,8 @@ +var modules = +[ + [ "Convolutional Neural Network Example", "group__CNNExample.html", null ], + [ "Gated Recurrent Unit Example", "group__GRUExample.html", null ], + [ "Neural Network Functions", "group__groupNN.html", "group__groupNN" ], + [ "Neural Network Data Conversion Functions", "group__nndata__convert.html", "group__nndata__convert" ], + [ "Basic Math Functions for Neural Network Computation", "group__NNBasicMath.html", "group__NNBasicMath" ] +]; \ No newline at end of file diff --git a/docs/NN/html/namespacemembers.html b/docs/NN/html/namespacemembers.html new file mode 100644 index 0000000..403dcf2 --- /dev/null +++ b/docs/NN/html/namespacemembers.html @@ -0,0 +1,181 @@ + + + + + +Namespace Members +CMSIS-NN: Namespace Members + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
Here is a list of all namespace members with links to the namespace documentation for each member:
+
+
+ + + + diff --git a/docs/NN/html/namespacemembers_func.html b/docs/NN/html/namespacemembers_func.html new file mode 100644 index 0000000..bcd2b1c --- /dev/null +++ b/docs/NN/html/namespacemembers_func.html @@ -0,0 +1,139 @@ + + + + + +Namespace Members +CMSIS-NN: Namespace Members + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
    +
  • convert_q7_q15_weights() +: para_gen +
  • +
  • convert_to_x4_weights() +: para_gen +
  • +
+
+
+ + + + diff --git a/docs/NN/html/namespacemembers_vars.html b/docs/NN/html/namespacemembers_vars.html new file mode 100644 index 0000000..e605bee --- /dev/null +++ b/docs/NN/html/namespacemembers_vars.html @@ -0,0 +1,175 @@ + + + + + +Namespace Members +CMSIS-NN: Namespace Members + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
+ + + + diff --git a/docs/NN/html/namespacepara__gen.html b/docs/NN/html/namespacepara__gen.html new file mode 100644 index 0000000..f99141c --- /dev/null +++ b/docs/NN/html/namespacepara__gen.html @@ -0,0 +1,373 @@ + + + + + +para_gen Namespace Reference +CMSIS-NN: para_gen Namespace Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
para_gen Namespace Reference
+
+
+ + + + + + +

+Functions

def convert_to_x4_weights
 
def convert_q7_q15_weights
 
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

+Variables

int vec_dim
 
int row_dim
 
tuple update_weight
 
tuple reset_weight
 
tuple hidden_weight
 
tuple update_bias
 
tuple reset_bias
 
tuple hidden_bias
 
tuple input_data1
 
tuple input_data2
 
tuple history_data
 
tuple outfile
 
tuple weight
 
tuple new_weight
 
+

Function Documentation

+ +
+
+ + + + + + + + +
def para_gen.convert_q7_q15_weights ( weights)
+
+ +
+
+ +
+
+ + + + + + + + +
def para_gen.convert_to_x4_weights ( weights)
+
+ +
+
+

Variable Documentation

+ +
+
+ + + + +
tuple para_gen.hidden_bias
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.hidden_weight
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.history_data
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.input_data1
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.input_data2
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.new_weight
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.outfile
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.reset_bias
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.reset_weight
+
+ +
+
+ +
+
+ + + + +
int para_gen.row_dim
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.update_bias
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.update_weight
+
+ +
+
+ +
+
+ + + + +
int para_gen.vec_dim
+
+ +
+
+ +
+
+ + + + +
tuple para_gen.weight
+
+ +
+
+
+
+ + + + diff --git a/docs/NN/html/namespaces.html b/docs/NN/html/namespaces.html new file mode 100644 index 0000000..12dae8a --- /dev/null +++ b/docs/NN/html/namespaces.html @@ -0,0 +1,133 @@ + + + + + +Namespace List +CMSIS-NN: Namespace List + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Namespace List
+
+
+
Here is a list of all namespaces with brief descriptions:
+ + +
\Npara_gen
+
+
+
+ + + + diff --git a/docs/NN/html/nav_f.png b/docs/NN/html/nav_f.png new file mode 100644 index 0000000..72a58a5 Binary files /dev/null and b/docs/NN/html/nav_f.png differ diff --git a/docs/NN/html/nav_g.png b/docs/NN/html/nav_g.png new file mode 100644 index 0000000..2093a23 Binary files /dev/null and b/docs/NN/html/nav_g.png differ diff --git a/docs/NN/html/nav_h.png b/docs/NN/html/nav_h.png new file mode 100644 index 0000000..33389b1 Binary files /dev/null and b/docs/NN/html/nav_h.png differ diff --git a/docs/NN/html/navtree.css b/docs/NN/html/navtree.css new file mode 100644 index 0000000..41a9cb9 --- /dev/null +++ b/docs/NN/html/navtree.css @@ -0,0 +1,143 @@ +#nav-tree .children_ul { + margin:0; + padding:4px; +} + +#nav-tree ul { + list-style:none outside none; + margin:0px; + padding:0px; +} + +#nav-tree li { + white-space:nowrap; + margin:0px; + padding:0px; +} + +#nav-tree .plus { + margin:0px; +} + +#nav-tree .selected { + background-image: url('tab_a.png'); + background-repeat:repeat-x; + color: #fff; + text-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); +} + +#nav-tree img { + margin:0px; + padding:0px; + border:0px; + vertical-align: middle; +} + +#nav-tree a { + text-decoration:none; + padding:0px; + margin:0px; + outline:none; +} + +#nav-tree .label { + margin:0px; + padding:0px; + font: 12px 'Lucida Grande',Geneva,Helvetica,Arial,sans-serif; +} + +#nav-tree .label a { + padding:2px; +} + +#nav-tree .selected a { + text-decoration:none; + color:#fff; +} + +#nav-tree .children_ul { + margin:0px; + padding:0px; +} + +#nav-tree .item { + margin:0px; + padding:0px; +} + +#nav-tree { + padding: 0px 0px; + background-color: #FAFAFF; + font-size:14px; + overflow:auto; +} + +#doc-content { + overflow:auto; + display:block; + padding:0px; + margin:0px; + -webkit-overflow-scrolling : touch; /* iOS 5+ */ +} + +#side-nav { + padding:0 6px 0 0; + margin: 0px; + display:block; + position: absolute; + left: 0px; + width: 250px; +} + +.ui-resizable .ui-resizable-handle { + display:block; +} + +.ui-resizable-e { + background:url("ftv2splitbar.png") repeat scroll right center transparent; + cursor:e-resize; + height:100%; + right:0; + top:0; + width:6px; +} + +.ui-resizable-handle { + display:none; + font-size:0.1px; + position:absolute; + z-index:1; +} + +#nav-tree-contents { + margin: 6px 0px 0px 0px; +} + +#nav-tree { + background-image:url('nav_h.png'); + background-repeat:repeat-x; + background-color: #F9FAFC; + -webkit-overflow-scrolling : touch; /* iOS 5+ */ +} + +#nav-sync { + position:absolute; + top:5px; + right:24px; + z-index:0; +} + +#nav-sync img { + opacity:0.3; +} + +#nav-sync img:hover { + opacity:0.9; +} + +@media print +{ + #nav-tree { display: none; } + div.ui-resizable-handle { display: none; position: relative; } +} + diff --git a/docs/NN/html/navtree.js b/docs/NN/html/navtree.js new file mode 100644 index 0000000..e16118c --- /dev/null +++ b/docs/NN/html/navtree.js @@ -0,0 +1,536 @@ +var NAVTREE = +[ + [ "CMSIS-NN", "index.html", [ + [ "CMSIS NN Software Library", "index.html", null ], + [ "Revision History of CMSIS-NN", "ChangeLog_pg.html", null ], + [ "Reference", "modules.html", "modules" ], + [ "Data Structures", "annotated.html", "annotated" ], + [ "Data Fields", "functions.html", [ + [ "All", "functions.html", null ], + [ "Variables", "functions_vars.html", null ] + ] ] + ] ] +]; + +var NAVTREEINDEX = +[ +"ChangeLog_pg.html" +]; + +var SYNCONMSG = 'click to disable panel synchronisation'; +var SYNCOFFMSG = 'click to enable panel synchronisation'; +var SYNCONMSG = 'click to disable panel synchronisation'; +var SYNCOFFMSG = 'click to enable panel synchronisation'; +var navTreeSubIndices = new Array(); + +function getData(varName) +{ + var i = varName.lastIndexOf('/'); + var n = i>=0 ? varName.substring(i+1) : varName; + return eval(n.replace(/\-/g,'_')); +} + +function stripPath(uri) +{ + return uri.substring(uri.lastIndexOf('/')+1); +} + +function stripPath2(uri) +{ + var i = uri.lastIndexOf('/'); + var s = uri.substring(i+1); + var m = uri.substring(0,i+1).match(/\/d\w\/d\w\w\/$/); + return m ? uri.substring(i-6) : s; +} + +function localStorageSupported() +{ + try { + return 'localStorage' in window && window['localStorage'] !== null && window.localStorage.getItem; + } + catch(e) { + return false; + } +} + + +function storeLink(link) +{ + if (!$("#nav-sync").hasClass('sync') && localStorageSupported()) { + window.localStorage.setItem('navpath',link); + } +} + +function deleteLink() +{ + if (localStorageSupported()) { + window.localStorage.setItem('navpath',''); + } +} + +function cachedLink() +{ + if (localStorageSupported()) { + return window.localStorage.getItem('navpath'); + } else { + return ''; + } +} + +function getScript(scriptName,func,show) +{ + var head = document.getElementsByTagName("head")[0]; + var script = document.createElement('script'); + script.id = scriptName; + script.type = 'text/javascript'; + script.onload = func; + script.src = scriptName+'.js'; + if ($.browser.msie && $.browser.version<=8) { + // script.onload does not work with older versions of IE + script.onreadystatechange = function() { + if (script.readyState=='complete' || script.readyState=='loaded') { + func(); if (show) showRoot(); + } + } + } + head.appendChild(script); +} + +function createIndent(o,domNode,node,level) +{ + var level=-1; + var n = node; + while (n.parentNode) { level++; n=n.parentNode; } + if (node.childrenData) { + var imgNode = document.createElement("img"); + imgNode.style.paddingLeft=(16*level).toString()+'px'; + imgNode.width = 16; + imgNode.height = 22; + imgNode.border = 0; + node.plus_img = imgNode; + node.expandToggle = document.createElement("a"); + node.expandToggle.href = "javascript:void(0)"; + node.expandToggle.onclick = function() { + if (node.expanded) { + $(node.getChildrenUL()).slideUp("fast"); + node.plus_img.src = node.relpath+"ftv2pnode.png"; + node.expanded = false; + } else { + expandNode(o, node, false, false); + } + } + node.expandToggle.appendChild(imgNode); + domNode.appendChild(node.expandToggle); + imgNode.src = node.relpath+"ftv2pnode.png"; + } else { + var span = document.createElement("span"); + span.style.display = 'inline-block'; + span.style.width = 16*(level+1)+'px'; + span.style.height = '22px'; + span.innerHTML = ' '; + domNode.appendChild(span); + } +} + +var animationInProgress = false; + +function gotoAnchor(anchor,aname,updateLocation) +{ + var pos, docContent = $('#doc-content'); + if (anchor.parent().attr('class')=='memItemLeft' || + anchor.parent().attr('class')=='fieldtype' || + anchor.parent().is(':header')) + { + pos = anchor.parent().position().top; + } else if (anchor.position()) { + pos = anchor.position().top; + } + if (pos) { + var dist = Math.abs(Math.min( + pos-docContent.offset().top, + docContent[0].scrollHeight- + docContent.height()-docContent.scrollTop())); + animationInProgress=true; + docContent.animate({ + scrollTop: pos + docContent.scrollTop() - docContent.offset().top + },Math.max(50,Math.min(500,dist)),function(){ + if (updateLocation) window.location.href=aname; + animationInProgress=false; + }); + } +} + +function newNode(o, po, text, link, childrenData, lastNode) +{ + var node = new Object(); + node.children = Array(); + node.childrenData = childrenData; + node.depth = po.depth + 1; + node.relpath = po.relpath; + node.isLast = lastNode; + + node.li = document.createElement("li"); + po.getChildrenUL().appendChild(node.li); + node.parentNode = po; + + node.itemDiv = document.createElement("div"); + node.itemDiv.className = "item"; + + node.labelSpan = document.createElement("span"); + node.labelSpan.className = "label"; + + createIndent(o,node.itemDiv,node,0); + node.itemDiv.appendChild(node.labelSpan); + node.li.appendChild(node.itemDiv); + + var a = document.createElement("a"); + node.labelSpan.appendChild(a); + node.label = document.createTextNode(text); + node.expanded = false; + a.appendChild(node.label); + if (link) { + var url; + if (link.substring(0,1)=='^') { + url = link.substring(1); + link = url; + } else { + url = node.relpath+link; + } + a.className = stripPath(link.replace('#',':')); + if (link.indexOf('#')!=-1) { + var aname = '#'+link.split('#')[1]; + var srcPage = stripPath($(location).attr('pathname')); + var targetPage = stripPath(link.split('#')[0]); + a.href = srcPage!=targetPage ? url : "javascript:void(0)"; + a.onclick = function(){ + storeLink(link); + if (!$(a).parent().parent().hasClass('selected')) + { + $('.item').removeClass('selected'); + $('.item').removeAttr('id'); + $(a).parent().parent().addClass('selected'); + $(a).parent().parent().attr('id','selected'); + } + var anchor = $(aname); + gotoAnchor(anchor,aname,true); + }; + } else { + a.href = url; + a.onclick = function() { storeLink(link); } + } + } else { + if (childrenData != null) + { + a.className = "nolink"; + a.href = "javascript:void(0)"; + a.onclick = node.expandToggle.onclick; + } + } + + node.childrenUL = null; + node.getChildrenUL = function() { + if (!node.childrenUL) { + node.childrenUL = document.createElement("ul"); + node.childrenUL.className = "children_ul"; + node.childrenUL.style.display = "none"; + node.li.appendChild(node.childrenUL); + } + return node.childrenUL; + }; + + return node; +} + +function showRoot() +{ + var headerHeight = $("#top").height(); + var footerHeight = $("#nav-path").height(); + var windowHeight = $(window).height() - headerHeight - footerHeight; + (function (){ // retry until we can scroll to the selected item + try { + var navtree=$('#nav-tree'); + navtree.scrollTo('#selected',0,{offset:-windowHeight/2}); + } catch (err) { + setTimeout(arguments.callee, 0); + } + })(); +} + +function expandNode(o, node, imm, showRoot) +{ + if (node.childrenData && !node.expanded) { + if (typeof(node.childrenData)==='string') { + var varName = node.childrenData; + getScript(node.relpath+varName,function(){ + node.childrenData = getData(varName); + expandNode(o, node, imm, showRoot); + }, showRoot); + } else { + if (!node.childrenVisited) { + getNode(o, node); + } if (imm || ($.browser.msie && $.browser.version>8)) { + // somehow slideDown jumps to the start of tree for IE9 :-( + $(node.getChildrenUL()).show(); + } else { + $(node.getChildrenUL()).slideDown("fast"); + } + if (node.isLast) { + node.plus_img.src = node.relpath+"ftv2mlastnode.png"; + } else { + node.plus_img.src = node.relpath+"ftv2mnode.png"; + } + node.expanded = true; + } + } +} + +function glowEffect(n,duration) +{ + n.addClass('glow').delay(duration).queue(function(next){ + $(this).removeClass('glow');next(); + }); +} + +function highlightAnchor() +{ + var aname = $(location).attr('hash'); + var anchor = $(aname); + if (anchor.parent().attr('class')=='memItemLeft'){ + var rows = $('.memberdecls tr[class$="'+ + window.location.hash.substring(1)+'"]'); + glowEffect(rows.children(),300); // member without details + } else if (anchor.parents().slice(2).prop('tagName')=='TR') { + glowEffect(anchor.parents('div.memitem'),1000); // enum value + } else if (anchor.parent().attr('class')=='fieldtype'){ + glowEffect(anchor.parent().parent(),1000); // struct field + } else if (anchor.parent().is(":header")) { + glowEffect(anchor.parent(),1000); // section header + } else { + glowEffect(anchor.next(),1000); // normal member + } + gotoAnchor(anchor,aname,false); +} + +function selectAndHighlight(hash,n) +{ + var a; + if (hash) { + var link=stripPath($(location).attr('pathname'))+':'+hash.substring(1); + a=$('.item a[class$="'+link+'"]'); + } + if (a && a.length) { + a.parent().parent().addClass('selected'); + a.parent().parent().attr('id','selected'); + highlightAnchor(); + } else if (n) { + $(n.itemDiv).addClass('selected'); + $(n.itemDiv).attr('id','selected'); + } + if ($('#nav-tree-contents .item:first').hasClass('selected')) { + $('#nav-sync').css('top','30px'); + } else { + $('#nav-sync').css('top','5px'); + } + showRoot(); +} + +function showNode(o, node, index, hash) +{ + if (node && node.childrenData) { + if (typeof(node.childrenData)==='string') { + var varName = node.childrenData; + getScript(node.relpath+varName,function(){ + node.childrenData = getData(varName); + showNode(o,node,index,hash); + },true); + } else { + if (!node.childrenVisited) { + getNode(o, node); + } + $(node.getChildrenUL()).css({'display':'block'}); + if (node.isLast) { + node.plus_img.src = node.relpath+"ftv2mlastnode.png"; + } else { + node.plus_img.src = node.relpath+"ftv2mnode.png"; + } + node.expanded = true; + var n = node.children[o.breadcrumbs[index]]; + if (index+11) hash = '#'+parts[1]; + else hash=''; + } + if (hash.match(/^#l\d+$/)) { + var anchor=$('a[name='+hash.substring(1)+']'); + glowEffect(anchor.parent(),1000); // line number + hash=''; // strip line number anchors + //root=root.replace(/_source\./,'.'); // source link to doc link + } + var url=root+hash; + var i=-1; + while (NAVTREEINDEX[i+1]<=url) i++; + if (i==-1) { i=0; root=NAVTREE[0][1]; } // fallback: show index + if (navTreeSubIndices[i]) { + gotoNode(o,i,root,hash,relpath) + } else { + getScript(relpath+'navtreeindex'+i,function(){ + navTreeSubIndices[i] = eval('NAVTREEINDEX'+i); + if (navTreeSubIndices[i]) { + gotoNode(o,i,root,hash,relpath); + } + },true); + } +} + +function showSyncOff(n,relpath) +{ + n.html(''); +} + +function showSyncOn(n,relpath) +{ + n.html(''); +} + +function toggleSyncButton(relpath) +{ + var navSync = $('#nav-sync'); + if (navSync.hasClass('sync')) { + navSync.removeClass('sync'); + showSyncOff(navSync,relpath); + storeLink(stripPath2($(location).attr('pathname'))+$(location).attr('hash')); + } else { + navSync.addClass('sync'); + showSyncOn(navSync,relpath); + deleteLink(); + } +} + +function initNavTree(toroot,relpath) +{ + var o = new Object(); + o.toroot = toroot; + o.node = new Object(); + o.node.li = document.getElementById("nav-tree-contents"); + o.node.childrenData = NAVTREE; + o.node.children = new Array(); + o.node.childrenUL = document.createElement("ul"); + o.node.getChildrenUL = function() { return o.node.childrenUL; }; + o.node.li.appendChild(o.node.childrenUL); + o.node.depth = 0; + o.node.relpath = relpath; + o.node.expanded = false; + o.node.isLast = true; + o.node.plus_img = document.createElement("img"); + o.node.plus_img.src = relpath+"ftv2pnode.png"; + o.node.plus_img.width = 16; + o.node.plus_img.height = 22; + + if (localStorageSupported()) { + var navSync = $('#nav-sync'); + if (cachedLink()) { + showSyncOff(navSync,relpath); + navSync.removeClass('sync'); + } else { + showSyncOn(navSync,relpath); + } + navSync.click(function(){ toggleSyncButton(relpath); }); + } + + $(window).load(function(){ + navTo(o,toroot,window.location.hash,relpath); + showRoot(); + }); + + $(window).bind('hashchange', function(){ + if (window.location.hash && window.location.hash.length>1){ + var a; + if ($(location).attr('hash')){ + var clslink=stripPath($(location).attr('pathname'))+':'+ + $(location).attr('hash').substring(1); + a=$('.item a[class$="'+clslink+'"]'); + } + if (a==null || !$(a).parent().parent().hasClass('selected')){ + $('.item').removeClass('selected'); + $('.item').removeAttr('id'); + } + var link=stripPath2($(location).attr('pathname')); + navTo(o,link,$(location).attr('hash'),relpath); + } else if (!animationInProgress) { + $('#doc-content').scrollTop(0); + $('.item').removeClass('selected'); + $('.item').removeAttr('id'); + navTo(o,toroot,window.location.hash,relpath); + } + }) +} + diff --git a/docs/NN/html/navtreeindex0.js b/docs/NN/html/navtreeindex0.js new file mode 100644 index 0000000..0b28663 --- /dev/null +++ b/docs/NN/html/navtreeindex0.js @@ -0,0 +1,55 @@ +var NAVTREEINDEX0 = +{ +"ChangeLog_pg.html":[1], +"annotated.html":[3], +"functions.html":[4,0], +"functions_vars.html":[4,1], +"group__Acti.html":[2,2,0], +"group__Acti.html#ga53bcc00e54b802919bb3c89c143ee5ba":[2,2,0,2], +"group__Acti.html#ga638e803b4fe00426f401783a6255ca30":[2,2,0,3], +"group__Acti.html#ga79f11131ae6767d60e03b1f6506b1af8":[2,2,0,1], +"group__Acti.html#ga8932b57c8d0ee757511af2d40dcc11e7":[2,2,0,0], +"group__CNNExample.html":[2,0], +"group__FC.html":[2,2,2], +"group__FC.html#ga062912078da113f5dd2004fd919a0ff2":[2,2,2,3], +"group__FC.html#ga4a1521e7532a1e62d71f3b12762016e2":[2,2,2,0], +"group__FC.html#ga8b7e0c2e989e8c75f0dc789f3115323d":[2,2,2,4], +"group__FC.html#gaac666c212b209e636c2369dd5c75d0dc":[2,2,2,2], +"group__FC.html#gae3857bb6375692e81dde8cbd70adec08":[2,2,2,1], +"group__FC.html#gaf82b71ef472a38f8fc9ac414d9d07e67":[2,2,2,5], +"group__GRUExample.html":[2,1], +"group__NNBasicMath.html":[2,4], +"group__NNBasicMath.html#ga08f8340aa6533271b3aa6d211614fe22":[2,4,0], +"group__NNBasicMath.html#gad46c9ab012cceda8ce6681c687a58c70":[2,4,1], +"group__NNConv.html":[2,2,1], +"group__NNConv.html#ga110adcfdaab356c750c6270aa5e05f29":[2,2,1,0], +"group__NNConv.html#ga210ae8d8fc1d12ee15b41f1fa6947681":[2,2,1,4], +"group__NNConv.html#ga32ac508c5467813a84f74f96655dc697":[2,2,1,10], +"group__NNConv.html#ga4501fa22c0836002aa47ccc313dce252":[2,2,1,5], +"group__NNConv.html#ga4efb1ccbbaa7dd936961989dcb443f50":[2,2,1,2], +"group__NNConv.html#ga55701f213b198084b52eab53097f1f58":[2,2,1,1], +"group__NNConv.html#ga614ec3b71eb96e29952ec3f09e7b9c3c":[2,2,1,3], +"group__NNConv.html#ga98f2ead67d7cbdf558b0cd8a3b8fc148":[2,2,1,8], +"group__NNConv.html#gabc6d6b991024e9e5c5cdbd7489de88ef":[2,2,1,7], +"group__NNConv.html#gad3d21b3bc6dbd6f3b97d01104349cb0a":[2,2,1,9], +"group__NNConv.html#gae00d3c1285907d59657369fc98bcc83f":[2,2,1,6], +"group__Pooling.html":[2,2,3], +"group__Pooling.html#ga99afcdcc61eaf429ab3ee823702e44ce":[2,2,3,1], +"group__Pooling.html#gae4a7b07f97ec4313524c9fb9fbcb1f6a":[2,2,3,0], +"group__Softmax.html":[2,2,4], +"group__Softmax.html#ga1cacd8b84b8363079311987d0016ebe5":[2,2,4,0], +"group__Softmax.html#ga89aff212a97a3cf32d9d7ddf11a8f43e":[2,2,4,1], +"group__groupNN.html":[2,2], +"group__nndata__convert.html":[2,3], +"group__nndata__convert.html#gaba8fd446d5f54760b406ee63b25d1aee":[2,3,1], +"group__nndata__convert.html#gae349de4dba8d253c89d45794ccf05680":[2,3,0], +"index.html":[], +"index.html":[0], +"modules.html":[2], +"namespacepara__gen.html":[3,0], +"pages.html":[], +"unionarm__nnword.html":[3,1], +"unionarm__nnword.html#a35c7b2ae25e35e0ddcd9ec0a1a6f8d18":[3,1,2], +"unionarm__nnword.html#a9b5e49e4e2c4b7203e07b305386bb2ba":[3,1,1], +"unionarm__nnword.html#ac7cff6480a8e29d95f29b73cb1267249":[3,1,0] +}; diff --git a/docs/NN/html/open.png b/docs/NN/html/open.png new file mode 100644 index 0000000..30f75c7 Binary files /dev/null and b/docs/NN/html/open.png differ diff --git a/docs/NN/html/pages.html b/docs/NN/html/pages.html new file mode 100644 index 0000000..981d68a --- /dev/null +++ b/docs/NN/html/pages.html @@ -0,0 +1,133 @@ + + + + + +Usage and Description +CMSIS-NN: Usage and Description + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+
+
Usage and Description
+
+
+
Here is a list of all related documentation pages:
+
+
+ + + + diff --git a/docs/NN/html/para__gen_8py.html b/docs/NN/html/para__gen_8py.html new file mode 100644 index 0000000..d02316d --- /dev/null +++ b/docs/NN/html/para__gen_8py.html @@ -0,0 +1,177 @@ + + + + + +para_gen.py File Reference +CMSIS-NN: para_gen.py File Reference + + + + + + + + + + + + + + +
+
+ + + + + + + +
+
CMSIS-NN +  Version 1.1.0 +
+
CMSIS NN Software Library
+
+
+ +
+
    + +
+
+ + + +
+
+ +
+
+
+ +
+ + + + +
+ +
+ +
+ +
+
para_gen.py File Reference
+
+
+ + + + +

+Namespaces

 para_gen
 
+ + + + + +

+Functions

def para_gen.convert_to_x4_weights
 
def para_gen.convert_q7_q15_weights
 
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

+Variables

int para_gen.vec_dim
 
int para_gen.row_dim
 
tuple para_gen.update_weight
 
tuple para_gen.reset_weight
 
tuple para_gen.hidden_weight
 
tuple para_gen.update_bias
 
tuple para_gen.reset_bias
 
tuple para_gen.hidden_bias
 
tuple para_gen.input_data1
 
tuple para_gen.input_data2
 
tuple para_gen.history_data
 
tuple para_gen.outfile
 
tuple para_gen.weight
 
tuple para_gen.new_weight
 
+
+
+ + + + diff --git a/docs/NN/html/printComponentTabs.js b/docs/NN/html/printComponentTabs.js new file mode 100644 index 0000000..8afdb6b --- /dev/null +++ b/docs/NN/html/printComponentTabs.js @@ -0,0 +1,39 @@ +var strgURL = location.pathname; // path of current component + +// constuctor for the array of objects +function tabElement(id, folderName, tabTxt ) { + this.id = id; // elementID as needed in html; + this.folderName = folderName; // folder name of the component + this.tabTxt = tabTxt; // Text displayed as menu on the web + this.currentListItem = '
  • ' + this.tabTxt + '
  • '; + this.listItem = '
  • ' + this.tabTxt + '
  • '; +}; + +// array of objects +var arr = []; + +// fill array + arr.push( new tabElement( "GEN", "/General/html/", "General") ); + arr.push( new tabElement( "CORE_A", "/Core_A/html/", "CMSIS-Core(A)") ); + arr.push( new tabElement( "CORE_M", "/Core/html/", "CMSIS-Core(M)") ); + arr.push( new tabElement( "DRV", "/Driver/html/", "Driver") ); + arr.push( new tabElement( "DSP", "/DSP/html/", "DSP") ); + arr.push( new tabElement( "NN", "/NN/html/", "NN") ); + arr.push( new tabElement( "RTOSv1", "/RTOS/html/", "RTOS v1") ); + arr.push( new tabElement( "RTOSv2", "/RTOS2/html/", "RTOS v2") ); + arr.push( new tabElement( "PACK", "/Pack/html/", "Pack") ); + arr.push( new tabElement( "SVD", "/SVD/html/", "SVD") ); + arr.push( new tabElement( "DAP", "/DAP/html/", "DAP") ); + arr.push( new tabElement( "ZONE", "/Zone/html/", "Zone") ); + +// write tabs +// called from the header file. +function writeComponentTabs() { + for ( var i=0; i < arr.length; i++ ) { + if (strgURL.search(arr[i].folderName) > 0) { // if this is the current folder + document.write(arr[i].currentListItem); // then print and hightlight the tab + } else { + document.write(arr[i].listItem); // else, print the tab + } + } +}; diff --git a/docs/NN/html/resize.js b/docs/NN/html/resize.js new file mode 100644 index 0000000..304fcb6 --- /dev/null +++ b/docs/NN/html/resize.js @@ -0,0 +1,97 @@ +var cookie_namespace = 'doxygen'; +var sidenav,navtree,content,header; + +function readCookie(cookie) +{ + var myCookie = cookie_namespace+"_"+cookie+"="; + if (document.cookie) + { + var index = document.cookie.indexOf(myCookie); + if (index != -1) + { + var valStart = index + myCookie.length; + var valEnd = document.cookie.indexOf(";", valStart); + if (valEnd == -1) + { + valEnd = document.cookie.length; + } + var val = document.cookie.substring(valStart, valEnd); + return val; + } + } + return 0; +} + +function writeCookie(cookie, val, expiration) +{ + if (val==undefined) return; + if (expiration == null) + { + var date = new Date(); + date.setTime(date.getTime()+(10*365*24*60*60*1000)); // default expiration is one week + expiration = date.toGMTString(); + } + document.cookie = cookie_namespace + "_" + cookie + "=" + val + "; expires=" + expiration+"; path=/"; +} + +function resizeWidth() +{ + var windowWidth = $(window).width() + "px"; + var sidenavWidth = $(sidenav).outerWidth(); + content.css({marginLeft:parseInt(sidenavWidth)+"px"}); + writeCookie('width',sidenavWidth, null); +} + +function restoreWidth(navWidth) +{ + var windowWidth = $(window).width() + "px"; + content.css({marginLeft:parseInt(navWidth)+6+"px"}); + sidenav.css({width:navWidth + "px"}); +} + +function resizeHeight() +{ + var headerHeight = header.outerHeight(); + var footerHeight = footer.outerHeight(); + var windowHeight = $(window).height() - headerHeight - footerHeight; + content.css({height:windowHeight + "px"}); + navtree.css({height:windowHeight + "px"}); + sidenav.css({height:windowHeight + "px",top: headerHeight+"px"}); +} + +function initResizable() +{ + header = $("#top"); + sidenav = $("#side-nav"); + content = $("#doc-content"); + navtree = $("#nav-tree"); + footer = $("#nav-path"); + $(".side-nav-resizable").resizable({resize: function(e, ui) { resizeWidth(); } }); + $(window).resize(function() { resizeHeight(); }); + var width = readCookie('width'); + if (width) { restoreWidth(width); } else { resizeWidth(); } + resizeHeight(); + var url = location.href; + var i=url.indexOf("#"); + if (i>=0) window.location.hash=url.substr(i); + var _preventDefault = function(evt) { evt.preventDefault(); }; + $("#splitbar").bind("dragstart", _preventDefault).bind("selectstart", _preventDefault); + $(document).bind('touchmove',function(e){ + var device = navigator.userAgent.toLowerCase(); + var ios = device.match(/(iphone|ipod|ipad)/); + if (ios) { + try { + var target = e.target; + while (target) { + if ($(target).css('-webkit-overflow-scrolling')=='touch') return; + target = target.parentNode; + } + e.preventDefault(); + } catch(err) { + e.preventDefault(); + } + } + }); +} + + diff --git a/docs/NN/html/search/all_0.html b/docs/NN/html/search/all_0.html new file mode 100644 index 0000000..17b6da8 --- /dev/null +++ b/docs/NN/html/search/all_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_0.js b/docs/NN/html/search/all_0.js new file mode 100644 index 0000000..0c14b6e --- /dev/null +++ b/docs/NN/html/search/all_0.js @@ -0,0 +1,78 @@ +var searchData= +[ + ['arm_5favepool_5fq7_5fhwc',['arm_avepool_q7_HWC',['../group__Pooling.html#gae4a7b07f97ec4313524c9fb9fbcb1f6a',1,'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): arm_pool_q7_HWC.c'],['../group__Pooling.html#gae4a7b07f97ec4313524c9fb9fbcb1f6a',1,'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): arm_pool_q7_HWC.c']]], + ['arm_5fconvolve_5f1x1_5fhwc_5fq7_5ffast_5fnonsquare',['arm_convolve_1x1_HWC_q7_fast_nonsquare',['../group__NNConv.html#ga110adcfdaab356c750c6270aa5e05f29',1,'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): arm_convolve_1x1_HWC_q7_fast_nonsquare.c'],['../group__NNConv.html#ga110adcfdaab356c750c6270aa5e05f29',1,'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): arm_convolve_1x1_HWC_q7_fast_nonsquare.c']]], + ['arm_5fconvolve_5f1x1_5fhwc_5fq7_5ffast_5fnonsquare_2ec',['arm_convolve_1x1_HWC_q7_fast_nonsquare.c',['../arm__convolve__1x1__HWC__q7__fast__nonsquare_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq15_5fbasic',['arm_convolve_HWC_q15_basic',['../group__NNConv.html#ga55701f213b198084b52eab53097f1f58',1,'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): arm_convolve_HWC_q15_basic.c'],['../group__NNConv.html#ga55701f213b198084b52eab53097f1f58',1,'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): arm_convolve_HWC_q15_basic.c']]], + ['arm_5fconvolve_5fhwc_5fq15_5fbasic_2ec',['arm_convolve_HWC_q15_basic.c',['../arm__convolve__HWC__q15__basic_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq15_5ffast',['arm_convolve_HWC_q15_fast',['../group__NNConv.html#ga4efb1ccbbaa7dd936961989dcb443f50',1,'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): arm_convolve_HWC_q15_fast.c'],['../group__NNConv.html#ga4efb1ccbbaa7dd936961989dcb443f50',1,'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): arm_convolve_HWC_q15_fast.c']]], + ['arm_5fconvolve_5fhwc_5fq15_5ffast_2ec',['arm_convolve_HWC_q15_fast.c',['../arm__convolve__HWC__q15__fast_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq15_5ffast_5fnonsquare',['arm_convolve_HWC_q15_fast_nonsquare',['../group__NNConv.html#ga614ec3b71eb96e29952ec3f09e7b9c3c',1,'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): arm_convolve_HWC_q15_fast_nonsquare.c'],['../group__NNConv.html#ga614ec3b71eb96e29952ec3f09e7b9c3c',1,'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): arm_convolve_HWC_q15_fast_nonsquare.c']]], + ['arm_5fconvolve_5fhwc_5fq15_5ffast_5fnonsquare_2ec',['arm_convolve_HWC_q15_fast_nonsquare.c',['../arm__convolve__HWC__q15__fast__nonsquare_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5fbasic',['arm_convolve_HWC_q7_basic',['../group__NNConv.html#ga210ae8d8fc1d12ee15b41f1fa6947681',1,'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): arm_convolve_HWC_q7_basic.c'],['../group__NNConv.html#ga210ae8d8fc1d12ee15b41f1fa6947681',1,'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): arm_convolve_HWC_q7_basic.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5fbasic_2ec',['arm_convolve_HWC_q7_basic.c',['../arm__convolve__HWC__q7__basic_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5fbasic_5fnonsquare',['arm_convolve_HWC_q7_basic_nonsquare',['../group__NNConv.html#ga4501fa22c0836002aa47ccc313dce252',1,'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): arm_convolve_HWC_q7_basic_nonsquare.c'],['../group__NNConv.html#ga4501fa22c0836002aa47ccc313dce252',1,'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): arm_convolve_HWC_q7_basic_nonsquare.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5fbasic_5fnonsquare_2ec',['arm_convolve_HWC_q7_basic_nonsquare.c',['../arm__convolve__HWC__q7__basic__nonsquare_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5ffast',['arm_convolve_HWC_q7_fast',['../group__NNConv.html#gae00d3c1285907d59657369fc98bcc83f',1,'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): arm_convolve_HWC_q7_fast.c'],['../group__NNConv.html#gae00d3c1285907d59657369fc98bcc83f',1,'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): arm_convolve_HWC_q7_fast.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5ffast_2ec',['arm_convolve_HWC_q7_fast.c',['../arm__convolve__HWC__q7__fast_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5ffast_5fnonsquare',['arm_convolve_HWC_q7_fast_nonsquare',['../group__NNConv.html#gabc6d6b991024e9e5c5cdbd7489de88ef',1,'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): arm_convolve_HWC_q7_fast_nonsquare.c'],['../group__NNConv.html#gabc6d6b991024e9e5c5cdbd7489de88ef',1,'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): arm_convolve_HWC_q7_fast_nonsquare.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5ffast_5fnonsquare_2ec',['arm_convolve_HWC_q7_fast_nonsquare.c',['../arm__convolve__HWC__q7__fast__nonsquare_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5frgb',['arm_convolve_HWC_q7_RGB',['../group__NNConv.html#ga98f2ead67d7cbdf558b0cd8a3b8fc148',1,'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): arm_convolve_HWC_q7_RGB.c'],['../group__NNConv.html#ga98f2ead67d7cbdf558b0cd8a3b8fc148',1,'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): arm_convolve_HWC_q7_RGB.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5frgb_2ec',['arm_convolve_HWC_q7_RGB.c',['../arm__convolve__HWC__q7__RGB_8c.html',1,'']]], + ['arm_5fdepthwise_5fseparable_5fconv_5fhwc_5fq7',['arm_depthwise_separable_conv_HWC_q7',['../group__NNConv.html#gad3d21b3bc6dbd6f3b97d01104349cb0a',1,'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): arm_depthwise_separable_conv_HWC_q7.c'],['../group__NNConv.html#gad3d21b3bc6dbd6f3b97d01104349cb0a',1,'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): arm_depthwise_separable_conv_HWC_q7.c']]], + ['arm_5fdepthwise_5fseparable_5fconv_5fhwc_5fq7_2ec',['arm_depthwise_separable_conv_HWC_q7.c',['../arm__depthwise__separable__conv__HWC__q7_8c.html',1,'']]], + ['arm_5fdepthwise_5fseparable_5fconv_5fhwc_5fq7_5fnonsquare',['arm_depthwise_separable_conv_HWC_q7_nonsquare',['../group__NNConv.html#ga32ac508c5467813a84f74f96655dc697',1,'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): arm_depthwise_separable_conv_HWC_q7_nonsquare.c'],['../group__NNConv.html#ga32ac508c5467813a84f74f96655dc697',1,'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): arm_depthwise_separable_conv_HWC_q7_nonsquare.c']]], + ['arm_5fdepthwise_5fseparable_5fconv_5fhwc_5fq7_5fnonsquare_2ec',['arm_depthwise_separable_conv_HWC_q7_nonsquare.c',['../arm__depthwise__separable__conv__HWC__q7__nonsquare_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fmat_5fq7_5fvec_5fq15',['arm_fully_connected_mat_q7_vec_q15',['../group__FC.html#ga4a1521e7532a1e62d71f3b12762016e2',1,'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): arm_fully_connected_mat_q7_vec_q15.c'],['../group__FC.html#ga4a1521e7532a1e62d71f3b12762016e2',1,'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): arm_fully_connected_mat_q7_vec_q15.c']]], + ['arm_5ffully_5fconnected_5fmat_5fq7_5fvec_5fq15_2ec',['arm_fully_connected_mat_q7_vec_q15.c',['../arm__fully__connected__mat__q7__vec__q15_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fmat_5fq7_5fvec_5fq15_5fopt',['arm_fully_connected_mat_q7_vec_q15_opt',['../group__FC.html#gae3857bb6375692e81dde8cbd70adec08',1,'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): arm_fully_connected_mat_q7_vec_q15_opt.c'],['../group__FC.html#gae3857bb6375692e81dde8cbd70adec08',1,'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): arm_fully_connected_mat_q7_vec_q15_opt.c']]], + ['arm_5ffully_5fconnected_5fmat_5fq7_5fvec_5fq15_5fopt_2ec',['arm_fully_connected_mat_q7_vec_q15_opt.c',['../arm__fully__connected__mat__q7__vec__q15__opt_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fq15',['arm_fully_connected_q15',['../group__FC.html#gaac666c212b209e636c2369dd5c75d0dc',1,'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): arm_fully_connected_q15.c'],['../group__FC.html#gaac666c212b209e636c2369dd5c75d0dc',1,'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): arm_fully_connected_q15.c']]], + ['arm_5ffully_5fconnected_5fq15_2ec',['arm_fully_connected_q15.c',['../arm__fully__connected__q15_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fq15_5fopt',['arm_fully_connected_q15_opt',['../group__FC.html#ga062912078da113f5dd2004fd919a0ff2',1,'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): arm_fully_connected_q15_opt.c'],['../group__FC.html#ga062912078da113f5dd2004fd919a0ff2',1,'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): arm_fully_connected_q15_opt.c']]], + ['arm_5ffully_5fconnected_5fq15_5fopt_2ec',['arm_fully_connected_q15_opt.c',['../arm__fully__connected__q15__opt_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fq7',['arm_fully_connected_q7',['../group__FC.html#ga8b7e0c2e989e8c75f0dc789f3115323d',1,'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): arm_fully_connected_q7.c'],['../group__FC.html#ga8b7e0c2e989e8c75f0dc789f3115323d',1,'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): arm_fully_connected_q7.c']]], + ['arm_5ffully_5fconnected_5fq7_2ec',['arm_fully_connected_q7.c',['../arm__fully__connected__q7_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fq7_5fopt',['arm_fully_connected_q7_opt',['../group__FC.html#gaf82b71ef472a38f8fc9ac414d9d07e67',1,'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): arm_fully_connected_q7_opt.c'],['../group__FC.html#gaf82b71ef472a38f8fc9ac414d9d07e67',1,'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): arm_fully_connected_q7_opt.c']]], + ['arm_5ffully_5fconnected_5fq7_5fopt_2ec',['arm_fully_connected_q7_opt.c',['../arm__fully__connected__q7__opt_8c.html',1,'']]], + ['arm_5fmaxpool_5fq7_5fhwc',['arm_maxpool_q7_HWC',['../group__Pooling.html#ga99afcdcc61eaf429ab3ee823702e44ce',1,'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): arm_pool_q7_HWC.c'],['../group__Pooling.html#ga99afcdcc61eaf429ab3ee823702e44ce',1,'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): arm_pool_q7_HWC.c']]], + ['arm_5fnn_5factivation_5ftype',['arm_nn_activation_type',['../arm__nnsupportfunctions_8h.html#a7f41aa78cd9a0552fae9b348ee4831a0',1,'arm_nnsupportfunctions.h']]], + ['arm_5fnn_5factivations_5fdirect_5fq15',['arm_nn_activations_direct_q15',['../group__Acti.html#ga8932b57c8d0ee757511af2d40dcc11e7',1,'arm_nn_activations_direct_q15(q15_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type): arm_nn_activations_q15.c'],['../group__Acti.html#ga8932b57c8d0ee757511af2d40dcc11e7',1,'arm_nn_activations_direct_q15(q15_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type): arm_nn_activations_q15.c']]], + ['arm_5fnn_5factivations_5fdirect_5fq7',['arm_nn_activations_direct_q7',['../group__Acti.html#ga79f11131ae6767d60e03b1f6506b1af8',1,'arm_nn_activations_direct_q7(q7_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type): arm_nn_activations_q7.c'],['../group__Acti.html#ga79f11131ae6767d60e03b1f6506b1af8',1,'arm_nn_activations_direct_q7(q7_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type): arm_nn_activations_q7.c']]], + ['arm_5fnn_5factivations_5fq15_2ec',['arm_nn_activations_q15.c',['../arm__nn__activations__q15_8c.html',1,'']]], + ['arm_5fnn_5factivations_5fq7_2ec',['arm_nn_activations_q7.c',['../arm__nn__activations__q7_8c.html',1,'']]], + ['arm_5fnn_5fmat_5fmult_5fkernel_5fq7_5fq15',['arm_nn_mat_mult_kernel_q7_q15',['../arm__nnfunctions_8h.html#abc4fb258cfe8500ee68e812a293a80a3',1,'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): arm_nn_mat_mult_kernel_q7_q15.c'],['../arm__nn__mat__mult__kernel__q7__q15_8c.html#abc4fb258cfe8500ee68e812a293a80a3',1,'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): arm_nn_mat_mult_kernel_q7_q15.c']]], + ['arm_5fnn_5fmat_5fmult_5fkernel_5fq7_5fq15_2ec',['arm_nn_mat_mult_kernel_q7_q15.c',['../arm__nn__mat__mult__kernel__q7__q15_8c.html',1,'']]], + ['arm_5fnn_5fmat_5fmult_5fkernel_5fq7_5fq15_5freordered',['arm_nn_mat_mult_kernel_q7_q15_reordered',['../arm__nnfunctions_8h.html#aefe9c7ce9a65060a244b06dffe74c4b3',1,'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): arm_nn_mat_mult_kernel_q7_q15_reordered.c'],['../arm__nn__mat__mult__kernel__q7__q15__reordered_8c.html#aefe9c7ce9a65060a244b06dffe74c4b3',1,'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): arm_nn_mat_mult_kernel_q7_q15_reordered.c']]], + ['arm_5fnn_5fmat_5fmult_5fkernel_5fq7_5fq15_5freordered_2ec',['arm_nn_mat_mult_kernel_q7_q15_reordered.c',['../arm__nn__mat__mult__kernel__q7__q15__reordered_8c.html',1,'']]], + ['arm_5fnn_5fmult_5fq15',['arm_nn_mult_q15',['../group__NNBasicMath.html#ga08f8340aa6533271b3aa6d211614fe22',1,'arm_nn_mult_q15(q15_t *pSrcA, q15_t *pSrcB, q15_t *pDst, const uint16_t out_shift, uint32_t blockSize): arm_nn_mult_q15.c'],['../group__NNBasicMath.html#ga08f8340aa6533271b3aa6d211614fe22',1,'arm_nn_mult_q15(q15_t *pSrcA, q15_t *pSrcB, q15_t *pDst, const uint16_t out_shift, uint32_t blockSize): arm_nn_mult_q15.c']]], + ['arm_5fnn_5fmult_5fq15_2ec',['arm_nn_mult_q15.c',['../arm__nn__mult__q15_8c.html',1,'']]], + ['arm_5fnn_5fmult_5fq7',['arm_nn_mult_q7',['../group__NNBasicMath.html#gad46c9ab012cceda8ce6681c687a58c70',1,'arm_nn_mult_q7(q7_t *pSrcA, q7_t *pSrcB, q7_t *pDst, const uint16_t out_shift, uint32_t blockSize): arm_nn_mult_q7.c'],['../group__NNBasicMath.html#gad46c9ab012cceda8ce6681c687a58c70',1,'arm_nn_mult_q7(q7_t *pSrcA, q7_t *pSrcB, q7_t *pDst, const uint16_t out_shift, uint32_t blockSize): arm_nn_mult_q7.c']]], + ['arm_5fnn_5fmult_5fq7_2ec',['arm_nn_mult_q7.c',['../arm__nn__mult__q7_8c.html',1,'']]], + ['arm_5fnn_5ftables_2eh',['arm_nn_tables.h',['../arm__nn__tables_8h.html',1,'']]], + ['arm_5fnnexamples_5fcifar10_2ecpp',['arm_nnexamples_cifar10.cpp',['../arm__nnexamples__cifar10_8cpp.html',1,'']]], + ['arm_5fnnexamples_5fcifar10_5finputs_2eh',['arm_nnexamples_cifar10_inputs.h',['../arm__nnexamples__cifar10__inputs_8h.html',1,'']]], + ['arm_5fnnexamples_5fcifar10_5fparameter_2eh',['arm_nnexamples_cifar10_parameter.h',['../arm__nnexamples__cifar10__parameter_8h.html',1,'']]], + ['arm_5fnnexamples_5fcifar10_5fweights_2eh',['arm_nnexamples_cifar10_weights.h',['../arm__nnexamples__cifar10__weights_8h.html',1,'']]], + ['arm_5fnnexamples_5fgru_2ecpp',['arm_nnexamples_gru.cpp',['../arm__nnexamples__gru_8cpp.html',1,'']]], + ['arm_5fnnexamples_5fgru_5ftest_5fdata_2eh',['arm_nnexamples_gru_test_data.h',['../arm__nnexamples__gru__test__data_8h.html',1,'']]], + ['arm_5fnnfunctions_2eh',['arm_nnfunctions.h',['../arm__nnfunctions_8h.html',1,'']]], + ['arm_5fnnsupportfunctions_2eh',['arm_nnsupportfunctions.h',['../arm__nnsupportfunctions_8h.html',1,'']]], + ['arm_5fnntables_2ec',['arm_nntables.c',['../arm__nntables_8c.html',1,'']]], + ['arm_5fnnword',['arm_nnword',['../unionarm__nnword.html',1,'']]], + ['arm_5fpool_5fq7_5fhwc_2ec',['arm_pool_q7_HWC.c',['../arm__pool__q7__HWC_8c.html',1,'']]], + ['arm_5fq7_5fto_5fq15_5fno_5fshift',['arm_q7_to_q15_no_shift',['../group__nndata__convert.html#gae349de4dba8d253c89d45794ccf05680',1,'arm_q7_to_q15_no_shift(const q7_t *pSrc, q15_t *pDst, uint32_t blockSize): arm_q7_to_q15_no_shift.c'],['../group__nndata__convert.html#gae349de4dba8d253c89d45794ccf05680',1,'arm_q7_to_q15_no_shift(const q7_t *pSrc, q15_t *pDst, uint32_t blockSize): arm_q7_to_q15_no_shift.c']]], + ['arm_5fq7_5fto_5fq15_5fno_5fshift_2ec',['arm_q7_to_q15_no_shift.c',['../arm__q7__to__q15__no__shift_8c.html',1,'']]], + ['arm_5fq7_5fto_5fq15_5freordered_5fno_5fshift',['arm_q7_to_q15_reordered_no_shift',['../group__nndata__convert.html#gaba8fd446d5f54760b406ee63b25d1aee',1,'arm_q7_to_q15_reordered_no_shift(const q7_t *pSrc, q15_t *pDst, uint32_t blockSize): arm_q7_to_q15_reordered_no_shift.c'],['../group__nndata__convert.html#gaba8fd446d5f54760b406ee63b25d1aee',1,'arm_q7_to_q15_reordered_no_shift(const q7_t *pSrc, q15_t *pDst, uint32_t blockSize): arm_q7_to_q15_reordered_no_shift.c']]], + ['arm_5fq7_5fto_5fq15_5freordered_5fno_5fshift_2ec',['arm_q7_to_q15_reordered_no_shift.c',['../arm__q7__to__q15__reordered__no__shift_8c.html',1,'']]], + ['arm_5frelu_5fq15',['arm_relu_q15',['../group__Acti.html#ga53bcc00e54b802919bb3c89c143ee5ba',1,'arm_relu_q15(q15_t *data, uint16_t size): arm_relu_q15.c'],['../group__Acti.html#ga53bcc00e54b802919bb3c89c143ee5ba',1,'arm_relu_q15(q15_t *data, uint16_t size): arm_relu_q15.c']]], + ['arm_5frelu_5fq15_2ec',['arm_relu_q15.c',['../arm__relu__q15_8c.html',1,'']]], + ['arm_5frelu_5fq7',['arm_relu_q7',['../group__Acti.html#ga638e803b4fe00426f401783a6255ca30',1,'arm_relu_q7(q7_t *data, uint16_t size): arm_relu_q7.c'],['../group__Acti.html#ga638e803b4fe00426f401783a6255ca30',1,'arm_relu_q7(q7_t *data, uint16_t size): arm_relu_q7.c']]], + ['arm_5frelu_5fq7_2ec',['arm_relu_q7.c',['../arm__relu__q7_8c.html',1,'']]], + ['arm_5fsigmoid',['ARM_SIGMOID',['../arm__nnsupportfunctions_8h.html#a7f41aa78cd9a0552fae9b348ee4831a0a49b307e029715fbaa6f3101c806b8c54',1,'arm_nnsupportfunctions.h']]], + ['arm_5fsoftmax_5fq15',['arm_softmax_q15',['../group__Softmax.html#ga1cacd8b84b8363079311987d0016ebe5',1,'arm_softmax_q15(const q15_t *vec_in, const uint16_t dim_vec, q15_t *p_out): arm_softmax_q15.c'],['../group__Softmax.html#ga1cacd8b84b8363079311987d0016ebe5',1,'arm_softmax_q15(const q15_t *vec_in, const uint16_t dim_vec, q15_t *p_out): arm_softmax_q15.c']]], + ['arm_5fsoftmax_5fq15_2ec',['arm_softmax_q15.c',['../arm__softmax__q15_8c.html',1,'']]], + ['arm_5fsoftmax_5fq7',['arm_softmax_q7',['../group__Softmax.html#ga89aff212a97a3cf32d9d7ddf11a8f43e',1,'arm_softmax_q7(const q7_t *vec_in, const uint16_t dim_vec, q7_t *p_out): arm_softmax_q7.c'],['../group__Softmax.html#ga89aff212a97a3cf32d9d7ddf11a8f43e',1,'arm_softmax_q7(const q7_t *vec_in, const uint16_t dim_vec, q7_t *p_out): arm_softmax_q7.c']]], + ['arm_5fsoftmax_5fq7_2ec',['arm_softmax_q7.c',['../arm__softmax__q7_8c.html',1,'']]], + ['arm_5ftanh',['ARM_TANH',['../arm__nnsupportfunctions_8h.html#a7f41aa78cd9a0552fae9b348ee4831a0ac24e4db95c986f16c10dca71a4b4e1c5',1,'arm_nnsupportfunctions.h']]] +]; diff --git a/docs/NN/html/search/all_1.html b/docs/NN/html/search/all_1.html new file mode 100644 index 0000000..e290644 --- /dev/null +++ b/docs/NN/html/search/all_1.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_1.js b/docs/NN/html/search/all_1.js new file mode 100644 index 0000000..fe49664 --- /dev/null +++ b/docs/NN/html/search/all_1.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['bytes',['bytes',['../unionarm__nnword.html#ac7cff6480a8e29d95f29b73cb1267249',1,'arm_nnword']]], + ['basic_20math_20functions_20for_20neural_20network_20computation',['Basic Math Functions for Neural Network Computation',['../group__NNBasicMath.html',1,'']]] +]; diff --git a/docs/NN/html/search/all_10.html b/docs/NN/html/search/all_10.html new file mode 100644 index 0000000..c55c836 --- /dev/null +++ b/docs/NN/html/search/all_10.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_10.js b/docs/NN/html/search/all_10.js new file mode 100644 index 0000000..0ea2ee4 --- /dev/null +++ b/docs/NN/html/search/all_10.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['vec_5fdim',['vec_dim',['../namespacepara__gen.html#ad97bcbf0472c82d537ee41c0196e3b2a',1,'para_gen']]] +]; diff --git a/docs/NN/html/search/all_11.html b/docs/NN/html/search/all_11.html new file mode 100644 index 0000000..6f3943a --- /dev/null +++ b/docs/NN/html/search/all_11.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_11.js b/docs/NN/html/search/all_11.js new file mode 100644 index 0000000..d84e951 --- /dev/null +++ b/docs/NN/html/search/all_11.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['weight',['weight',['../namespacepara__gen.html#af3dbe004474bc66ad55591f470ff008c',1,'para_gen']]], + ['word',['word',['../unionarm__nnword.html#a35c7b2ae25e35e0ddcd9ec0a1a6f8d18',1,'arm_nnword']]] +]; diff --git a/docs/NN/html/search/all_2.html b/docs/NN/html/search/all_2.html new file mode 100644 index 0000000..95ded12 --- /dev/null +++ b/docs/NN/html/search/all_2.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_2.js b/docs/NN/html/search/all_2.js new file mode 100644 index 0000000..56f9ee0 --- /dev/null +++ b/docs/NN/html/search/all_2.js @@ -0,0 +1,42 @@ +var searchData= +[ + ['convolutional_20neural_20network_20example',['Convolutional Neural Network Example',['../group__CNNExample.html',1,'']]], + ['col_5fbuffer',['col_buffer',['../arm__nnexamples__cifar10_8cpp.html#a1f988afc6d7fe29ded1eafbf79a70386',1,'arm_nnexamples_cifar10.cpp']]], + ['conv1_5fbias',['CONV1_BIAS',['../arm__nnexamples__cifar10__weights_8h.html#a4cb0cfbbb61aa122890a656646532eeb',1,'CONV1_BIAS(): arm_nnexamples_cifar10_weights.h'],['../arm__nnexamples__cifar10_8cpp.html#a2dd28923edd6ae13ec6e61e1d876650c',1,'conv1_bias(): arm_nnexamples_cifar10.cpp']]], + ['conv1_5fbias_5flshift',['CONV1_BIAS_LSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a4150dd1364fd3534561c5c6e530f9bfb',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv1_5fim_5fch',['CONV1_IM_CH',['../arm__nnexamples__cifar10__parameter_8h.html#aea8b1c41a63cf63eb6e7f049e84f22f7',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fim_5fdim',['CONV1_IM_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a23ded220d27415ee1f6d9ac0bfdf38cb',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fker_5fdim',['CONV1_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#ad51c611a952fac7102ca15a06eabb908',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fout_5fch',['CONV1_OUT_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a3c1777ba8f883a5490beb3d79050c8dc',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fout_5fdim',['CONV1_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a6262e2cd96ec12681024ab4ac73d607b',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fout_5frshift',['CONV1_OUT_RSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#aa8f89682da16a15a092d06097a5696d3',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv1_5fpadding',['CONV1_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#a2bb0fafdfd2c283df4708ec53f3d90f7',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fstride',['CONV1_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#a596cdcf742e142edc29a0a0e44496c7c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fwt',['CONV1_WT',['../arm__nnexamples__cifar10__weights_8h.html#a257ee65177e8e51191b5204f3fda8dca',1,'CONV1_WT(): arm_nnexamples_cifar10_weights.h'],['../arm__nnexamples__cifar10_8cpp.html#a230b7412ffaaa297340ddcb49c828b4b',1,'conv1_wt(): arm_nnexamples_cifar10.cpp']]], + ['conv2_5fbias',['conv2_bias',['../arm__nnexamples__cifar10_8cpp.html#a686e558e4de77f778c775c9f0c9866d0',1,'conv2_bias(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__cifar10__weights_8h.html#adbdb9a359c8e4104203e3783d8c1adb1',1,'CONV2_BIAS(): arm_nnexamples_cifar10_weights.h']]], + ['conv2_5fbias_5flshift',['CONV2_BIAS_LSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#afa70cc595390d9205c78a58795f070f4',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv2_5fim_5fch',['CONV2_IM_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a060a8a5766a5eecaff9294f57301c99c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fim_5fdim',['CONV2_IM_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a832f71006d5c1e2bedbbcf192308d40e',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fker_5fdim',['CONV2_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a95b397cea14323e9037604cfcd245c26',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fout_5fch',['CONV2_OUT_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a3be645ea438c983786878c0198ed9ae8',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fout_5fdim',['CONV2_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a9953ead804e13dcd90d96dda64a330a4',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fout_5frshift',['CONV2_OUT_RSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#ad872d34bfa54d86f9e5177dd2ff40d79',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv2_5fpadding',['CONV2_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#a39c1c3497169012a512219446613be0c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fstride',['CONV2_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#a04f3292f8c8bac6dab973fb74eab2aa1',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fwt',['conv2_wt',['../arm__nnexamples__cifar10_8cpp.html#a52875a8218c39da056e6d5bfb2030230',1,'conv2_wt(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__cifar10__weights_8h.html#a9fd43e19e65f000a8b28d9f3505f0f6f',1,'CONV2_WT(): arm_nnexamples_cifar10_weights.h']]], + ['conv3_5fbias',['conv3_bias',['../arm__nnexamples__cifar10_8cpp.html#a70b571cac288e0d371eb9f5e7c3ccbdd',1,'conv3_bias(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__cifar10__weights_8h.html#a8047897a26edb638e4f8c01734eb969b',1,'CONV3_BIAS(): arm_nnexamples_cifar10_weights.h']]], + ['conv3_5fbias_5flshift',['CONV3_BIAS_LSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a5457926e12a9e6b0ae9754d509fb7918',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv3_5fim_5fch',['CONV3_IM_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a1d0f9b2d219527c5070e20c50c0ced41',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fim_5fdim',['CONV3_IM_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a04ab2b7e8de2668e0087448664814f87',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fker_5fdim',['CONV3_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a045174d68a25bfd7691303f1a063ac72',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fout_5fch',['CONV3_OUT_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a2ab3ad342128296bb1102c3632131fd7',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fout_5fdim',['CONV3_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#acf75167523a29737f045cc2280ce0914',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fout_5frshift',['CONV3_OUT_RSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#ae38425db927f582d7b5edfcfaa03c676',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv3_5fpadding',['CONV3_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#af7824a30efdeefbf468c24a70678131a',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fstride',['CONV3_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#af6ff8c82aa2d1f58a125fe71169b7cc1',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fwt',['conv3_wt',['../arm__nnexamples__cifar10_8cpp.html#a174a146d0ffaa32b073c84d95c489fed',1,'conv3_wt(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__cifar10__weights_8h.html#aa3605f1b1fafb1612311727d9b97b0f2',1,'CONV3_WT(): arm_nnexamples_cifar10_weights.h']]], + ['convert_5fq7_5fq15_5fweights',['convert_q7_q15_weights',['../namespacepara__gen.html#a75db0b43a1b942aa87ff10fd3b73dc8d',1,'para_gen']]], + ['convert_5fto_5fx4_5fweights',['convert_to_x4_weights',['../namespacepara__gen.html#ab7f5de20ae32542da9f83a8e99850722',1,'para_gen']]], + ['cmsis_20nn_20software_20library',['CMSIS NN Software Library',['../index.html',1,'']]], + ['readme_2etxt',['readme.txt',['../cifar10_2readme_8txt.html',1,'']]] +]; diff --git a/docs/NN/html/search/all_3.html b/docs/NN/html/search/all_3.html new file mode 100644 index 0000000..4d312d0 --- /dev/null +++ b/docs/NN/html/search/all_3.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_3.js b/docs/NN/html/search/all_3.js new file mode 100644 index 0000000..f8e6784 --- /dev/null +++ b/docs/NN/html/search/all_3.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['dim_5fhistory',['DIM_HISTORY',['../arm__nnexamples__gru_8cpp.html#ad9fde6ff501c9cd8a6cfc45949464c49',1,'arm_nnexamples_gru.cpp']]], + ['dim_5finput',['DIM_INPUT',['../arm__nnexamples__gru_8cpp.html#ac8ab7c242bba66633b8c06966da6c9bc',1,'arm_nnexamples_gru.cpp']]], + ['dim_5fvec',['DIM_VEC',['../arm__nnexamples__gru_8cpp.html#a9b4b56c701e4258f8f6c87f225fbcebc',1,'arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/all_4.html b/docs/NN/html/search/all_4.html new file mode 100644 index 0000000..d72a910 --- /dev/null +++ b/docs/NN/html/search/all_4.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_4.js b/docs/NN/html/search/all_4.js new file mode 100644 index 0000000..4a44fa7 --- /dev/null +++ b/docs/NN/html/search/all_4.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['fully_2dconnected_20layer_20functions',['Fully-connected Layer Functions',['../group__FC.html',1,'']]] +]; diff --git a/docs/NN/html/search/all_5.html b/docs/NN/html/search/all_5.html new file mode 100644 index 0000000..99ef726 --- /dev/null +++ b/docs/NN/html/search/all_5.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_5.js b/docs/NN/html/search/all_5.js new file mode 100644 index 0000000..8db7175 --- /dev/null +++ b/docs/NN/html/search/all_5.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['gru_5fexample',['gru_example',['../arm__nnexamples__gru_8cpp.html#ac71a806472c7c0c284a2253e71a6a27b',1,'arm_nnexamples_gru.cpp']]], + ['gated_20recurrent_20unit_20example',['Gated Recurrent Unit Example',['../group__GRUExample.html',1,'']]], + ['readme_2etxt',['readme.txt',['../gru_2readme_8txt.html',1,'']]] +]; diff --git a/docs/NN/html/search/all_6.html b/docs/NN/html/search/all_6.html new file mode 100644 index 0000000..6133ab3 --- /dev/null +++ b/docs/NN/html/search/all_6.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_6.js b/docs/NN/html/search/all_6.js new file mode 100644 index 0000000..73e719e --- /dev/null +++ b/docs/NN/html/search/all_6.js @@ -0,0 +1,12 @@ +var searchData= +[ + ['half_5fwords',['half_words',['../unionarm__nnword.html#a9b5e49e4e2c4b7203e07b305386bb2ba',1,'arm_nnword']]], + ['hidden_5fbias',['hidden_bias',['../namespacepara__gen.html#a0f6c4400e131b103d2fd89e420d6c308',1,'para_gen']]], + ['hidden_5fstate_5fbias',['hidden_state_bias',['../arm__nnexamples__gru_8cpp.html#a40dda695923891899cb86b2f01bfd98a',1,'hidden_state_bias(): arm_nnexamples_gru.cpp'],['../arm__nnexamples__gru__test__data_8h.html#a73d4e38a4aa9fa9d761d08d33b3a07fd',1,'HIDDEN_STATE_BIAS(): arm_nnexamples_gru_test_data.h']]], + ['hidden_5fstate_5fweight_5fx2',['HIDDEN_STATE_WEIGHT_X2',['../arm__nnexamples__gru__test__data_8h.html#a9ab9fa603208647d992b3367a757979b',1,'arm_nnexamples_gru_test_data.h']]], + ['hidden_5fstate_5fweight_5fx4',['HIDDEN_STATE_WEIGHT_X4',['../arm__nnexamples__gru__test__data_8h.html#a619947523492a72ab306da514e843ae3',1,'arm_nnexamples_gru_test_data.h']]], + ['hidden_5fstate_5fweights',['hidden_state_weights',['../arm__nnexamples__gru_8cpp.html#ab18783e8d8449d7222ec4a64dfcc92e6',1,'arm_nnexamples_gru.cpp']]], + ['hidden_5fweight',['hidden_weight',['../namespacepara__gen.html#a1a6edb73b72a6bbf443e6e450186660c',1,'para_gen']]], + ['history_2etxt',['history.txt',['../history_8txt.html',1,'']]], + ['history_5fdata',['HISTORY_DATA',['../arm__nnexamples__gru__test__data_8h.html#a55c93e4e823bca1e77f4487d1ab9c056',1,'HISTORY_DATA(): arm_nnexamples_gru_test_data.h'],['../namespacepara__gen.html#acdb294668ecca9a6f849afa4156883cd',1,'para_gen.history_data()']]] +]; diff --git a/docs/NN/html/search/all_7.html b/docs/NN/html/search/all_7.html new file mode 100644 index 0000000..5748125 --- /dev/null +++ b/docs/NN/html/search/all_7.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_7.js b/docs/NN/html/search/all_7.js new file mode 100644 index 0000000..d7b88ff --- /dev/null +++ b/docs/NN/html/search/all_7.js @@ -0,0 +1,17 @@ +var searchData= +[ + ['image_5fdata',['image_data',['../arm__nnexamples__cifar10_8cpp.html#aafa3e1726dde028f2dcce4febc1e9197',1,'arm_nnexamples_cifar10.cpp']]], + ['img_5fdata',['IMG_DATA',['../arm__nnexamples__cifar10__inputs_8h.html#a82161fe5498521048731fc21a04577c3',1,'arm_nnexamples_cifar10_inputs.h']]], + ['input_5fdata1',['INPUT_DATA1',['../arm__nnexamples__gru__test__data_8h.html#a1b0f5149443198bdde521a0a06c453c1',1,'INPUT_DATA1(): arm_nnexamples_gru_test_data.h'],['../namespacepara__gen.html#a845220c0c6574ced6cdaf7b1d2983d6d',1,'para_gen.input_data1()']]], + ['input_5fdata2',['INPUT_DATA2',['../arm__nnexamples__gru__test__data_8h.html#ae0d8a5f051f29980e62884ec34668026',1,'INPUT_DATA2(): arm_nnexamples_gru_test_data.h'],['../namespacepara__gen.html#acb820c3015e6a212ad2fe82f7939965a',1,'para_gen.input_data2()']]], + ['input_5fmean_5fshift',['INPUT_MEAN_SHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a476266acb4adb419f566006dce8829c3',1,'arm_nnexamples_cifar10_weights.h']]], + ['input_5fright_5fshift',['INPUT_RIGHT_SHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a4205de60010d416664775e3aa0f9ec62',1,'arm_nnexamples_cifar10_weights.h']]], + ['ip1_5fbias',['ip1_bias',['../arm__nnexamples__cifar10_8cpp.html#af715ce48798db09f3bed1753fed5c5fb',1,'ip1_bias(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__cifar10__weights_8h.html#ac88810411c45272e8f9144682b9d85bc',1,'IP1_BIAS(): arm_nnexamples_cifar10_weights.h']]], + ['ip1_5fbias_5flshift',['IP1_BIAS_LSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a3a98024d4e4c7fa2fbbc216812fb9b35',1,'arm_nnexamples_cifar10_weights.h']]], + ['ip1_5fdim',['IP1_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a5777b4b3cc406dc06397ba2d5bed9fda',1,'arm_nnexamples_cifar10_parameter.h']]], + ['ip1_5fim_5fch',['IP1_IM_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a3e4df285b7ca272ee897be69575ab6c5',1,'arm_nnexamples_cifar10_parameter.h']]], + ['ip1_5fim_5fdim',['IP1_IM_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a4c4ae51cf7195762dd43ea13825277be',1,'arm_nnexamples_cifar10_parameter.h']]], + ['ip1_5fout',['IP1_OUT',['../arm__nnexamples__cifar10__parameter_8h.html#aa7cda996b7185414b1af9762e37ac66f',1,'arm_nnexamples_cifar10_parameter.h']]], + ['ip1_5fout_5frshift',['IP1_OUT_RSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a67fad411ab3695e450e62ad0509a7eec',1,'arm_nnexamples_cifar10_weights.h']]], + ['ip1_5fwt',['ip1_wt',['../arm__nnexamples__cifar10_8cpp.html#a244dc5b6679b33a0a85b55adbe969208',1,'ip1_wt(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__cifar10__weights_8h.html#ad77644a78b16c4bd9f7a12a0406004ed',1,'IP1_WT(): arm_nnexamples_cifar10_weights.h']]] +]; diff --git a/docs/NN/html/search/all_8.html b/docs/NN/html/search/all_8.html new file mode 100644 index 0000000..0179bdd --- /dev/null +++ b/docs/NN/html/search/all_8.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_8.js b/docs/NN/html/search/all_8.js new file mode 100644 index 0000000..5bb2b40 --- /dev/null +++ b/docs/NN/html/search/all_8.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['main',['main',['../arm__nnexamples__cifar10_8cpp.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__gru_8cpp.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main(): arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/all_9.html b/docs/NN/html/search/all_9.html new file mode 100644 index 0000000..cd46d44 --- /dev/null +++ b/docs/NN/html/search/all_9.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_9.js b/docs/NN/html/search/all_9.js new file mode 100644 index 0000000..15a642b --- /dev/null +++ b/docs/NN/html/search/all_9.js @@ -0,0 +1,10 @@ +var searchData= +[ + ['neural_20network_20activation_20functions',['Neural Network Activation Functions',['../group__Acti.html',1,'']]], + ['neural_20network_20functions',['Neural Network Functions',['../group__groupNN.html',1,'']]], + ['new_5fweight',['new_weight',['../namespacepara__gen.html#aead9af07b473ce5bbd93619e3319355c',1,'para_gen']]], + ['nn_5fround',['NN_ROUND',['../arm__nnsupportfunctions_8h.html#a4cbd428a2b4a4f6b2a6e4219520c7ce0',1,'arm_nnsupportfunctions.h']]], + ['neural_20network_20convolution_20functions',['Neural Network Convolution Functions',['../group__NNConv.html',1,'']]], + ['neural_20network_20data_20conversion_20functions',['Neural Network Data Conversion Functions',['../group__nndata__convert.html',1,'']]], + ['neural_20network_20pooling_20functions',['Neural Network Pooling Functions',['../group__Pooling.html',1,'']]] +]; diff --git a/docs/NN/html/search/all_a.html b/docs/NN/html/search/all_a.html new file mode 100644 index 0000000..eab6553 --- /dev/null +++ b/docs/NN/html/search/all_a.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_a.js b/docs/NN/html/search/all_a.js new file mode 100644 index 0000000..60ee6dc --- /dev/null +++ b/docs/NN/html/search/all_a.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['outfile',['outfile',['../namespacepara__gen.html#a2e1a6685422a591fcb7801e9fd8ad574',1,'para_gen']]], + ['output_5fdata',['output_data',['../arm__nnexamples__cifar10_8cpp.html#a75c8e3727f7d3637f03ffb1d9f727313',1,'arm_nnexamples_cifar10.cpp']]] +]; diff --git a/docs/NN/html/search/all_b.html b/docs/NN/html/search/all_b.html new file mode 100644 index 0000000..a2c161e --- /dev/null +++ b/docs/NN/html/search/all_b.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_b.js b/docs/NN/html/search/all_b.js new file mode 100644 index 0000000..3e635e9 --- /dev/null +++ b/docs/NN/html/search/all_b.js @@ -0,0 +1,17 @@ +var searchData= +[ + ['para_5fgen',['para_gen',['../namespacepara__gen.html',1,'']]], + ['para_5fgen_2epy',['para_gen.py',['../para__gen_8py.html',1,'']]], + ['pool1_5fker_5fdim',['POOL1_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a5324f2e7e894dd4c9eb2f3b92dd5516c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool1_5fout_5fdim',['POOL1_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a13553cac577d5430e3e43508c5ab6b7b',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool1_5fpadding',['POOL1_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#a537abddfc374d05a2513d1cc74b5721b',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool1_5fstride',['POOL1_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#acad52b60f0a0457ffb643cef69df0c0c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool2_5fker_5fdim',['POOL2_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a1b0c6e280d189658130b8b81c6991425',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool2_5fout_5fdim',['POOL2_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#ada358cd9b0a9b48a2666e9bfcee90aef',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool2_5fpadding',['POOL2_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#a9508f70a2798099db07a6d9b8f892126',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool2_5fstride',['POOL2_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#a158e111c343e144ec2461ea94ab11ab2',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool3_5fker_5fdim',['POOL3_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a32a30cfd6d89ab4fdbfad9732d71297d',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool3_5fout_5fdim',['POOL3_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#ae4a4616060ad43b06d5c1aea834a25e5',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool3_5fpadding',['POOL3_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#aac063e83339cc89308fb23a6922a5d98',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool3_5fstride',['POOL3_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#a74efaa8ffffc0437b54143878ac8cde7',1,'arm_nnexamples_cifar10_parameter.h']]] +]; diff --git a/docs/NN/html/search/all_c.html b/docs/NN/html/search/all_c.html new file mode 100644 index 0000000..bdd3ee2 --- /dev/null +++ b/docs/NN/html/search/all_c.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_c.js b/docs/NN/html/search/all_c.js new file mode 100644 index 0000000..316a0f0 --- /dev/null +++ b/docs/NN/html/search/all_c.js @@ -0,0 +1,11 @@ +var searchData= +[ + ['revision_20history_20of_20cmsis_2dnn',['Revision History of CMSIS-NN',['../ChangeLog_pg.html',1,'']]], + ['reset_5fbias',['reset_bias',['../namespacepara__gen.html#a3da798c88974b5d760f3e97288a0c490',1,'para_gen']]], + ['reset_5fgate_5fbias',['reset_gate_bias',['../arm__nnexamples__gru_8cpp.html#a2a9d5c9f16ee778ecc8170d8664722c7',1,'reset_gate_bias(): arm_nnexamples_gru.cpp'],['../arm__nnexamples__gru__test__data_8h.html#a8b4b6522d1ab0d6c51a1fe3c51d0020d',1,'RESET_GATE_BIAS(): arm_nnexamples_gru_test_data.h']]], + ['reset_5fgate_5fweight_5fx2',['RESET_GATE_WEIGHT_X2',['../arm__nnexamples__gru__test__data_8h.html#a52f158cb32bf2b46e3d2c4b94876db75',1,'arm_nnexamples_gru_test_data.h']]], + ['reset_5fgate_5fweight_5fx4',['RESET_GATE_WEIGHT_X4',['../arm__nnexamples__gru__test__data_8h.html#a177dc986b0c728df8628a205719be0ee',1,'arm_nnexamples_gru_test_data.h']]], + ['reset_5fgate_5fweights',['reset_gate_weights',['../arm__nnexamples__gru_8cpp.html#ac2ae1ff19167c2bb359db2b319ca1060',1,'arm_nnexamples_gru.cpp']]], + ['reset_5fweight',['reset_weight',['../namespacepara__gen.html#a4ebba057829420c878a0a29ee9c71582',1,'para_gen']]], + ['row_5fdim',['row_dim',['../namespacepara__gen.html#a26cc0a96186b2e6b238d783d9364f14d',1,'para_gen']]] +]; diff --git a/docs/NN/html/search/all_d.html b/docs/NN/html/search/all_d.html new file mode 100644 index 0000000..d510933 --- /dev/null +++ b/docs/NN/html/search/all_d.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_d.js b/docs/NN/html/search/all_d.js new file mode 100644 index 0000000..de9cb35 --- /dev/null +++ b/docs/NN/html/search/all_d.js @@ -0,0 +1,9 @@ +var searchData= +[ + ['scratch_5fbuffer',['scratch_buffer',['../arm__nnexamples__cifar10_8cpp.html#a19548b1fad7cb85d95f5f276873a5de3',1,'scratch_buffer(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__gru_8cpp.html#a935afa741bcc39e4c4c48b019d415d97',1,'scratch_buffer(): arm_nnexamples_gru.cpp']]], + ['sigmoidhtable_5fq15',['sigmoidHTable_q15',['../arm__nn__tables_8h.html#ab5096856d08f98c906b9b02e6c6a8bdf',1,'sigmoidHTable_q15(): arm_nn_tables.h'],['../arm__nntables_8c.html#a107a16eaa36f4392fa3ed3792ad6c2cb',1,'sigmoidHTable_q15(): arm_nntables.c']]], + ['sigmoidltable_5fq15',['sigmoidLTable_q15',['../arm__nn__tables_8h.html#add5ca535701805d3cb61287219975838',1,'sigmoidLTable_q15(): arm_nn_tables.h'],['../arm__nntables_8c.html#a69dc528cb377690d5b37accfdfd226b1',1,'sigmoidLTable_q15(): arm_nntables.c']]], + ['sigmoidtable_5fq15',['sigmoidTable_q15',['../arm__nn__tables_8h.html#ab4d7b07c387a3537d4efe21da86115b0',1,'sigmoidTable_q15(): arm_nntables.c'],['../arm__nntables_8c.html#ab4d7b07c387a3537d4efe21da86115b0',1,'sigmoidTable_q15(): arm_nntables.c']]], + ['sigmoidtable_5fq7',['sigmoidTable_q7',['../arm__nn__tables_8h.html#ae2ff3f4e7014f535358167150bdd544f',1,'sigmoidTable_q7(): arm_nntables.c'],['../arm__nntables_8c.html#ae2ff3f4e7014f535358167150bdd544f',1,'sigmoidTable_q7(): arm_nntables.c']]], + ['softmax_20functions',['Softmax Functions',['../group__Softmax.html',1,'']]] +]; diff --git a/docs/NN/html/search/all_e.html b/docs/NN/html/search/all_e.html new file mode 100644 index 0000000..3cda017 --- /dev/null +++ b/docs/NN/html/search/all_e.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_e.js b/docs/NN/html/search/all_e.js new file mode 100644 index 0000000..1857c2e --- /dev/null +++ b/docs/NN/html/search/all_e.js @@ -0,0 +1,10 @@ +var searchData= +[ + ['tanhhtable_5fq15',['tanhHTable_q15',['../arm__nntables_8c.html#a4d093f7b0dc798d4898ff4fd125b21a6',1,'arm_nntables.c']]], + ['tanhltable_5fq15',['tanhLTable_q15',['../arm__nntables_8c.html#a7cb5ad2fff7e241d09024332488a706e',1,'arm_nntables.c']]], + ['tanhtable_5fq15',['tanhTable_q15',['../arm__nn__tables_8h.html#a6faad2fec173b2702fd0f219a83ca320',1,'tanhTable_q15(): arm_nntables.c'],['../arm__nntables_8c.html#a6faad2fec173b2702fd0f219a83ca320',1,'tanhTable_q15(): arm_nntables.c']]], + ['tanhtable_5fq7',['tanhTable_q7',['../arm__nn__tables_8h.html#a4f854bdf13f630ec21b3ad074491e32f',1,'tanhTable_q7(): arm_nntables.c'],['../arm__nntables_8c.html#a4f854bdf13f630ec21b3ad074491e32f',1,'tanhTable_q7(): arm_nntables.c']]], + ['test_5fhistory',['test_history',['../arm__nnexamples__gru_8cpp.html#ac327d41d23812b53d83c2da91971cbfe',1,'arm_nnexamples_gru.cpp']]], + ['test_5finput1',['test_input1',['../arm__nnexamples__gru_8cpp.html#a8b0acc149c9bd4aadfb9c1fa8345f57a',1,'arm_nnexamples_gru.cpp']]], + ['test_5finput2',['test_input2',['../arm__nnexamples__gru_8cpp.html#aad5944359ea4a426550a87efd0d90b02',1,'arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/all_f.html b/docs/NN/html/search/all_f.html new file mode 100644 index 0000000..7419b02 --- /dev/null +++ b/docs/NN/html/search/all_f.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/all_f.js b/docs/NN/html/search/all_f.js new file mode 100644 index 0000000..b4cffb3 --- /dev/null +++ b/docs/NN/html/search/all_f.js @@ -0,0 +1,11 @@ +var searchData= +[ + ['update_5fbias',['update_bias',['../namespacepara__gen.html#a3b9bab83acf3b4296f46165da08ddbc9',1,'para_gen']]], + ['update_5fgate_5fbias',['UPDATE_GATE_BIAS',['../arm__nnexamples__gru__test__data_8h.html#a89f5a888f55a353a914ccf6542c41f0b',1,'UPDATE_GATE_BIAS(): arm_nnexamples_gru_test_data.h'],['../arm__nnexamples__gru_8cpp.html#ac5569d687768d693618f987a91e8aee5',1,'update_gate_bias(): arm_nnexamples_gru.cpp']]], + ['update_5fgate_5fweight_5fx2',['UPDATE_GATE_WEIGHT_X2',['../arm__nnexamples__gru__test__data_8h.html#ab753489637dfba855233303733416a73',1,'arm_nnexamples_gru_test_data.h']]], + ['update_5fgate_5fweight_5fx4',['UPDATE_GATE_WEIGHT_X4',['../arm__nnexamples__gru__test__data_8h.html#abb89228c76ad50a997938f676153b77f',1,'arm_nnexamples_gru_test_data.h']]], + ['update_5fgate_5fweights',['update_gate_weights',['../arm__nnexamples__gru_8cpp.html#aa2fc9b2b0449790ed7c37bab7fd3093e',1,'arm_nnexamples_gru.cpp']]], + ['update_5fweight',['update_weight',['../namespacepara__gen.html#ab8ce9efdee9cd118a25831839f9c5943',1,'para_gen']]], + ['use_5fintrinsic',['USE_INTRINSIC',['../arm__nnfunctions_8h.html#a710b6e009261290c6151f329cf409530',1,'arm_nnfunctions.h']]], + ['use_5fx4',['USE_X4',['../arm__nnexamples__gru_8cpp.html#a206812c9f4afd792e23a8d842ffa2984',1,'arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/classes_0.html b/docs/NN/html/search/classes_0.html new file mode 100644 index 0000000..fabdc03 --- /dev/null +++ b/docs/NN/html/search/classes_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/classes_0.js b/docs/NN/html/search/classes_0.js new file mode 100644 index 0000000..30fbd4a --- /dev/null +++ b/docs/NN/html/search/classes_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['arm_5fnnword',['arm_nnword',['../unionarm__nnword.html',1,'']]] +]; diff --git a/docs/NN/html/search/close.png b/docs/NN/html/search/close.png new file mode 100644 index 0000000..9342d3d Binary files /dev/null and b/docs/NN/html/search/close.png differ diff --git a/docs/NN/html/search/defines_0.html b/docs/NN/html/search/defines_0.html new file mode 100644 index 0000000..c2f0b46 --- /dev/null +++ b/docs/NN/html/search/defines_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/defines_0.js b/docs/NN/html/search/defines_0.js new file mode 100644 index 0000000..f2ef9a0 --- /dev/null +++ b/docs/NN/html/search/defines_0.js @@ -0,0 +1,36 @@ +var searchData= +[ + ['conv1_5fbias',['CONV1_BIAS',['../arm__nnexamples__cifar10__weights_8h.html#a4cb0cfbbb61aa122890a656646532eeb',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv1_5fbias_5flshift',['CONV1_BIAS_LSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a4150dd1364fd3534561c5c6e530f9bfb',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv1_5fim_5fch',['CONV1_IM_CH',['../arm__nnexamples__cifar10__parameter_8h.html#aea8b1c41a63cf63eb6e7f049e84f22f7',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fim_5fdim',['CONV1_IM_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a23ded220d27415ee1f6d9ac0bfdf38cb',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fker_5fdim',['CONV1_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#ad51c611a952fac7102ca15a06eabb908',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fout_5fch',['CONV1_OUT_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a3c1777ba8f883a5490beb3d79050c8dc',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fout_5fdim',['CONV1_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a6262e2cd96ec12681024ab4ac73d607b',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fout_5frshift',['CONV1_OUT_RSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#aa8f89682da16a15a092d06097a5696d3',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv1_5fpadding',['CONV1_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#a2bb0fafdfd2c283df4708ec53f3d90f7',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fstride',['CONV1_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#a596cdcf742e142edc29a0a0e44496c7c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv1_5fwt',['CONV1_WT',['../arm__nnexamples__cifar10__weights_8h.html#a257ee65177e8e51191b5204f3fda8dca',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv2_5fbias',['CONV2_BIAS',['../arm__nnexamples__cifar10__weights_8h.html#adbdb9a359c8e4104203e3783d8c1adb1',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv2_5fbias_5flshift',['CONV2_BIAS_LSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#afa70cc595390d9205c78a58795f070f4',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv2_5fim_5fch',['CONV2_IM_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a060a8a5766a5eecaff9294f57301c99c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fim_5fdim',['CONV2_IM_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a832f71006d5c1e2bedbbcf192308d40e',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fker_5fdim',['CONV2_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a95b397cea14323e9037604cfcd245c26',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fout_5fch',['CONV2_OUT_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a3be645ea438c983786878c0198ed9ae8',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fout_5fdim',['CONV2_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a9953ead804e13dcd90d96dda64a330a4',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fout_5frshift',['CONV2_OUT_RSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#ad872d34bfa54d86f9e5177dd2ff40d79',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv2_5fpadding',['CONV2_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#a39c1c3497169012a512219446613be0c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fstride',['CONV2_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#a04f3292f8c8bac6dab973fb74eab2aa1',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv2_5fwt',['CONV2_WT',['../arm__nnexamples__cifar10__weights_8h.html#a9fd43e19e65f000a8b28d9f3505f0f6f',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv3_5fbias',['CONV3_BIAS',['../arm__nnexamples__cifar10__weights_8h.html#a8047897a26edb638e4f8c01734eb969b',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv3_5fbias_5flshift',['CONV3_BIAS_LSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a5457926e12a9e6b0ae9754d509fb7918',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv3_5fim_5fch',['CONV3_IM_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a1d0f9b2d219527c5070e20c50c0ced41',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fim_5fdim',['CONV3_IM_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a04ab2b7e8de2668e0087448664814f87',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fker_5fdim',['CONV3_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a045174d68a25bfd7691303f1a063ac72',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fout_5fch',['CONV3_OUT_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a2ab3ad342128296bb1102c3632131fd7',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fout_5fdim',['CONV3_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#acf75167523a29737f045cc2280ce0914',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fout_5frshift',['CONV3_OUT_RSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#ae38425db927f582d7b5edfcfaa03c676',1,'arm_nnexamples_cifar10_weights.h']]], + ['conv3_5fpadding',['CONV3_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#af7824a30efdeefbf468c24a70678131a',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fstride',['CONV3_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#af6ff8c82aa2d1f58a125fe71169b7cc1',1,'arm_nnexamples_cifar10_parameter.h']]], + ['conv3_5fwt',['CONV3_WT',['../arm__nnexamples__cifar10__weights_8h.html#aa3605f1b1fafb1612311727d9b97b0f2',1,'arm_nnexamples_cifar10_weights.h']]] +]; diff --git a/docs/NN/html/search/defines_1.html b/docs/NN/html/search/defines_1.html new file mode 100644 index 0000000..9e1d9fa --- /dev/null +++ b/docs/NN/html/search/defines_1.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/defines_1.js b/docs/NN/html/search/defines_1.js new file mode 100644 index 0000000..f8e6784 --- /dev/null +++ b/docs/NN/html/search/defines_1.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['dim_5fhistory',['DIM_HISTORY',['../arm__nnexamples__gru_8cpp.html#ad9fde6ff501c9cd8a6cfc45949464c49',1,'arm_nnexamples_gru.cpp']]], + ['dim_5finput',['DIM_INPUT',['../arm__nnexamples__gru_8cpp.html#ac8ab7c242bba66633b8c06966da6c9bc',1,'arm_nnexamples_gru.cpp']]], + ['dim_5fvec',['DIM_VEC',['../arm__nnexamples__gru_8cpp.html#a9b4b56c701e4258f8f6c87f225fbcebc',1,'arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/defines_2.html b/docs/NN/html/search/defines_2.html new file mode 100644 index 0000000..6ef4b98 --- /dev/null +++ b/docs/NN/html/search/defines_2.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/defines_2.js b/docs/NN/html/search/defines_2.js new file mode 100644 index 0000000..8701bbb --- /dev/null +++ b/docs/NN/html/search/defines_2.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['hidden_5fstate_5fbias',['HIDDEN_STATE_BIAS',['../arm__nnexamples__gru__test__data_8h.html#a73d4e38a4aa9fa9d761d08d33b3a07fd',1,'arm_nnexamples_gru_test_data.h']]], + ['hidden_5fstate_5fweight_5fx2',['HIDDEN_STATE_WEIGHT_X2',['../arm__nnexamples__gru__test__data_8h.html#a9ab9fa603208647d992b3367a757979b',1,'arm_nnexamples_gru_test_data.h']]], + ['hidden_5fstate_5fweight_5fx4',['HIDDEN_STATE_WEIGHT_X4',['../arm__nnexamples__gru__test__data_8h.html#a619947523492a72ab306da514e843ae3',1,'arm_nnexamples_gru_test_data.h']]], + ['history_5fdata',['HISTORY_DATA',['../arm__nnexamples__gru__test__data_8h.html#a55c93e4e823bca1e77f4487d1ab9c056',1,'arm_nnexamples_gru_test_data.h']]] +]; diff --git a/docs/NN/html/search/defines_3.html b/docs/NN/html/search/defines_3.html new file mode 100644 index 0000000..e575d66 --- /dev/null +++ b/docs/NN/html/search/defines_3.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/defines_3.js b/docs/NN/html/search/defines_3.js new file mode 100644 index 0000000..d6706f5 --- /dev/null +++ b/docs/NN/html/search/defines_3.js @@ -0,0 +1,16 @@ +var searchData= +[ + ['img_5fdata',['IMG_DATA',['../arm__nnexamples__cifar10__inputs_8h.html#a82161fe5498521048731fc21a04577c3',1,'arm_nnexamples_cifar10_inputs.h']]], + ['input_5fdata1',['INPUT_DATA1',['../arm__nnexamples__gru__test__data_8h.html#a1b0f5149443198bdde521a0a06c453c1',1,'arm_nnexamples_gru_test_data.h']]], + ['input_5fdata2',['INPUT_DATA2',['../arm__nnexamples__gru__test__data_8h.html#ae0d8a5f051f29980e62884ec34668026',1,'arm_nnexamples_gru_test_data.h']]], + ['input_5fmean_5fshift',['INPUT_MEAN_SHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a476266acb4adb419f566006dce8829c3',1,'arm_nnexamples_cifar10_weights.h']]], + ['input_5fright_5fshift',['INPUT_RIGHT_SHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a4205de60010d416664775e3aa0f9ec62',1,'arm_nnexamples_cifar10_weights.h']]], + ['ip1_5fbias',['IP1_BIAS',['../arm__nnexamples__cifar10__weights_8h.html#ac88810411c45272e8f9144682b9d85bc',1,'arm_nnexamples_cifar10_weights.h']]], + ['ip1_5fbias_5flshift',['IP1_BIAS_LSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a3a98024d4e4c7fa2fbbc216812fb9b35',1,'arm_nnexamples_cifar10_weights.h']]], + ['ip1_5fdim',['IP1_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a5777b4b3cc406dc06397ba2d5bed9fda',1,'arm_nnexamples_cifar10_parameter.h']]], + ['ip1_5fim_5fch',['IP1_IM_CH',['../arm__nnexamples__cifar10__parameter_8h.html#a3e4df285b7ca272ee897be69575ab6c5',1,'arm_nnexamples_cifar10_parameter.h']]], + ['ip1_5fim_5fdim',['IP1_IM_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a4c4ae51cf7195762dd43ea13825277be',1,'arm_nnexamples_cifar10_parameter.h']]], + ['ip1_5fout',['IP1_OUT',['../arm__nnexamples__cifar10__parameter_8h.html#aa7cda996b7185414b1af9762e37ac66f',1,'arm_nnexamples_cifar10_parameter.h']]], + ['ip1_5fout_5frshift',['IP1_OUT_RSHIFT',['../arm__nnexamples__cifar10__weights_8h.html#a67fad411ab3695e450e62ad0509a7eec',1,'arm_nnexamples_cifar10_weights.h']]], + ['ip1_5fwt',['IP1_WT',['../arm__nnexamples__cifar10__weights_8h.html#ad77644a78b16c4bd9f7a12a0406004ed',1,'arm_nnexamples_cifar10_weights.h']]] +]; diff --git a/docs/NN/html/search/defines_4.html b/docs/NN/html/search/defines_4.html new file mode 100644 index 0000000..90e654d --- /dev/null +++ b/docs/NN/html/search/defines_4.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/defines_4.js b/docs/NN/html/search/defines_4.js new file mode 100644 index 0000000..24e985a --- /dev/null +++ b/docs/NN/html/search/defines_4.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['nn_5fround',['NN_ROUND',['../arm__nnsupportfunctions_8h.html#a4cbd428a2b4a4f6b2a6e4219520c7ce0',1,'arm_nnsupportfunctions.h']]] +]; diff --git a/docs/NN/html/search/defines_5.html b/docs/NN/html/search/defines_5.html new file mode 100644 index 0000000..e02f8a2 --- /dev/null +++ b/docs/NN/html/search/defines_5.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/defines_5.js b/docs/NN/html/search/defines_5.js new file mode 100644 index 0000000..a3b3766 --- /dev/null +++ b/docs/NN/html/search/defines_5.js @@ -0,0 +1,15 @@ +var searchData= +[ + ['pool1_5fker_5fdim',['POOL1_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a5324f2e7e894dd4c9eb2f3b92dd5516c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool1_5fout_5fdim',['POOL1_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a13553cac577d5430e3e43508c5ab6b7b',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool1_5fpadding',['POOL1_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#a537abddfc374d05a2513d1cc74b5721b',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool1_5fstride',['POOL1_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#acad52b60f0a0457ffb643cef69df0c0c',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool2_5fker_5fdim',['POOL2_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a1b0c6e280d189658130b8b81c6991425',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool2_5fout_5fdim',['POOL2_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#ada358cd9b0a9b48a2666e9bfcee90aef',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool2_5fpadding',['POOL2_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#a9508f70a2798099db07a6d9b8f892126',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool2_5fstride',['POOL2_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#a158e111c343e144ec2461ea94ab11ab2',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool3_5fker_5fdim',['POOL3_KER_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#a32a30cfd6d89ab4fdbfad9732d71297d',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool3_5fout_5fdim',['POOL3_OUT_DIM',['../arm__nnexamples__cifar10__parameter_8h.html#ae4a4616060ad43b06d5c1aea834a25e5',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool3_5fpadding',['POOL3_PADDING',['../arm__nnexamples__cifar10__parameter_8h.html#aac063e83339cc89308fb23a6922a5d98',1,'arm_nnexamples_cifar10_parameter.h']]], + ['pool3_5fstride',['POOL3_STRIDE',['../arm__nnexamples__cifar10__parameter_8h.html#a74efaa8ffffc0437b54143878ac8cde7',1,'arm_nnexamples_cifar10_parameter.h']]] +]; diff --git a/docs/NN/html/search/defines_6.html b/docs/NN/html/search/defines_6.html new file mode 100644 index 0000000..52aef19 --- /dev/null +++ b/docs/NN/html/search/defines_6.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/defines_6.js b/docs/NN/html/search/defines_6.js new file mode 100644 index 0000000..93acc59 --- /dev/null +++ b/docs/NN/html/search/defines_6.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['reset_5fgate_5fbias',['RESET_GATE_BIAS',['../arm__nnexamples__gru__test__data_8h.html#a8b4b6522d1ab0d6c51a1fe3c51d0020d',1,'arm_nnexamples_gru_test_data.h']]], + ['reset_5fgate_5fweight_5fx2',['RESET_GATE_WEIGHT_X2',['../arm__nnexamples__gru__test__data_8h.html#a52f158cb32bf2b46e3d2c4b94876db75',1,'arm_nnexamples_gru_test_data.h']]], + ['reset_5fgate_5fweight_5fx4',['RESET_GATE_WEIGHT_X4',['../arm__nnexamples__gru__test__data_8h.html#a177dc986b0c728df8628a205719be0ee',1,'arm_nnexamples_gru_test_data.h']]] +]; diff --git a/docs/NN/html/search/defines_7.html b/docs/NN/html/search/defines_7.html new file mode 100644 index 0000000..1a4527c --- /dev/null +++ b/docs/NN/html/search/defines_7.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/defines_7.js b/docs/NN/html/search/defines_7.js new file mode 100644 index 0000000..721f363 --- /dev/null +++ b/docs/NN/html/search/defines_7.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['update_5fgate_5fbias',['UPDATE_GATE_BIAS',['../arm__nnexamples__gru__test__data_8h.html#a89f5a888f55a353a914ccf6542c41f0b',1,'arm_nnexamples_gru_test_data.h']]], + ['update_5fgate_5fweight_5fx2',['UPDATE_GATE_WEIGHT_X2',['../arm__nnexamples__gru__test__data_8h.html#ab753489637dfba855233303733416a73',1,'arm_nnexamples_gru_test_data.h']]], + ['update_5fgate_5fweight_5fx4',['UPDATE_GATE_WEIGHT_X4',['../arm__nnexamples__gru__test__data_8h.html#abb89228c76ad50a997938f676153b77f',1,'arm_nnexamples_gru_test_data.h']]], + ['use_5fintrinsic',['USE_INTRINSIC',['../arm__nnfunctions_8h.html#a710b6e009261290c6151f329cf409530',1,'arm_nnfunctions.h']]], + ['use_5fx4',['USE_X4',['../arm__nnexamples__gru_8cpp.html#a206812c9f4afd792e23a8d842ffa2984',1,'arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/enums_0.html b/docs/NN/html/search/enums_0.html new file mode 100644 index 0000000..b4cbe1e --- /dev/null +++ b/docs/NN/html/search/enums_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/enums_0.js b/docs/NN/html/search/enums_0.js new file mode 100644 index 0000000..6e13f3c --- /dev/null +++ b/docs/NN/html/search/enums_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['arm_5fnn_5factivation_5ftype',['arm_nn_activation_type',['../arm__nnsupportfunctions_8h.html#a7f41aa78cd9a0552fae9b348ee4831a0',1,'arm_nnsupportfunctions.h']]] +]; diff --git a/docs/NN/html/search/enumvalues_0.html b/docs/NN/html/search/enumvalues_0.html new file mode 100644 index 0000000..3e00fcf --- /dev/null +++ b/docs/NN/html/search/enumvalues_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/enumvalues_0.js b/docs/NN/html/search/enumvalues_0.js new file mode 100644 index 0000000..2c48429 --- /dev/null +++ b/docs/NN/html/search/enumvalues_0.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['arm_5fsigmoid',['ARM_SIGMOID',['../arm__nnsupportfunctions_8h.html#a7f41aa78cd9a0552fae9b348ee4831a0a49b307e029715fbaa6f3101c806b8c54',1,'arm_nnsupportfunctions.h']]], + ['arm_5ftanh',['ARM_TANH',['../arm__nnsupportfunctions_8h.html#a7f41aa78cd9a0552fae9b348ee4831a0ac24e4db95c986f16c10dca71a4b4e1c5',1,'arm_nnsupportfunctions.h']]] +]; diff --git a/docs/NN/html/search/files_0.html b/docs/NN/html/search/files_0.html new file mode 100644 index 0000000..c7aa36c --- /dev/null +++ b/docs/NN/html/search/files_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/files_0.js b/docs/NN/html/search/files_0.js new file mode 100644 index 0000000..13934d4 --- /dev/null +++ b/docs/NN/html/search/files_0.js @@ -0,0 +1,43 @@ +var searchData= +[ + ['arm_5fconvolve_5f1x1_5fhwc_5fq7_5ffast_5fnonsquare_2ec',['arm_convolve_1x1_HWC_q7_fast_nonsquare.c',['../arm__convolve__1x1__HWC__q7__fast__nonsquare_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq15_5fbasic_2ec',['arm_convolve_HWC_q15_basic.c',['../arm__convolve__HWC__q15__basic_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq15_5ffast_2ec',['arm_convolve_HWC_q15_fast.c',['../arm__convolve__HWC__q15__fast_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq15_5ffast_5fnonsquare_2ec',['arm_convolve_HWC_q15_fast_nonsquare.c',['../arm__convolve__HWC__q15__fast__nonsquare_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5fbasic_2ec',['arm_convolve_HWC_q7_basic.c',['../arm__convolve__HWC__q7__basic_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5fbasic_5fnonsquare_2ec',['arm_convolve_HWC_q7_basic_nonsquare.c',['../arm__convolve__HWC__q7__basic__nonsquare_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5ffast_2ec',['arm_convolve_HWC_q7_fast.c',['../arm__convolve__HWC__q7__fast_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5ffast_5fnonsquare_2ec',['arm_convolve_HWC_q7_fast_nonsquare.c',['../arm__convolve__HWC__q7__fast__nonsquare_8c.html',1,'']]], + ['arm_5fconvolve_5fhwc_5fq7_5frgb_2ec',['arm_convolve_HWC_q7_RGB.c',['../arm__convolve__HWC__q7__RGB_8c.html',1,'']]], + ['arm_5fdepthwise_5fseparable_5fconv_5fhwc_5fq7_2ec',['arm_depthwise_separable_conv_HWC_q7.c',['../arm__depthwise__separable__conv__HWC__q7_8c.html',1,'']]], + ['arm_5fdepthwise_5fseparable_5fconv_5fhwc_5fq7_5fnonsquare_2ec',['arm_depthwise_separable_conv_HWC_q7_nonsquare.c',['../arm__depthwise__separable__conv__HWC__q7__nonsquare_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fmat_5fq7_5fvec_5fq15_2ec',['arm_fully_connected_mat_q7_vec_q15.c',['../arm__fully__connected__mat__q7__vec__q15_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fmat_5fq7_5fvec_5fq15_5fopt_2ec',['arm_fully_connected_mat_q7_vec_q15_opt.c',['../arm__fully__connected__mat__q7__vec__q15__opt_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fq15_2ec',['arm_fully_connected_q15.c',['../arm__fully__connected__q15_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fq15_5fopt_2ec',['arm_fully_connected_q15_opt.c',['../arm__fully__connected__q15__opt_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fq7_2ec',['arm_fully_connected_q7.c',['../arm__fully__connected__q7_8c.html',1,'']]], + ['arm_5ffully_5fconnected_5fq7_5fopt_2ec',['arm_fully_connected_q7_opt.c',['../arm__fully__connected__q7__opt_8c.html',1,'']]], + ['arm_5fnn_5factivations_5fq15_2ec',['arm_nn_activations_q15.c',['../arm__nn__activations__q15_8c.html',1,'']]], + ['arm_5fnn_5factivations_5fq7_2ec',['arm_nn_activations_q7.c',['../arm__nn__activations__q7_8c.html',1,'']]], + ['arm_5fnn_5fmat_5fmult_5fkernel_5fq7_5fq15_2ec',['arm_nn_mat_mult_kernel_q7_q15.c',['../arm__nn__mat__mult__kernel__q7__q15_8c.html',1,'']]], + ['arm_5fnn_5fmat_5fmult_5fkernel_5fq7_5fq15_5freordered_2ec',['arm_nn_mat_mult_kernel_q7_q15_reordered.c',['../arm__nn__mat__mult__kernel__q7__q15__reordered_8c.html',1,'']]], + ['arm_5fnn_5fmult_5fq15_2ec',['arm_nn_mult_q15.c',['../arm__nn__mult__q15_8c.html',1,'']]], + ['arm_5fnn_5fmult_5fq7_2ec',['arm_nn_mult_q7.c',['../arm__nn__mult__q7_8c.html',1,'']]], + ['arm_5fnn_5ftables_2eh',['arm_nn_tables.h',['../arm__nn__tables_8h.html',1,'']]], + ['arm_5fnnexamples_5fcifar10_2ecpp',['arm_nnexamples_cifar10.cpp',['../arm__nnexamples__cifar10_8cpp.html',1,'']]], + ['arm_5fnnexamples_5fcifar10_5finputs_2eh',['arm_nnexamples_cifar10_inputs.h',['../arm__nnexamples__cifar10__inputs_8h.html',1,'']]], + ['arm_5fnnexamples_5fcifar10_5fparameter_2eh',['arm_nnexamples_cifar10_parameter.h',['../arm__nnexamples__cifar10__parameter_8h.html',1,'']]], + ['arm_5fnnexamples_5fcifar10_5fweights_2eh',['arm_nnexamples_cifar10_weights.h',['../arm__nnexamples__cifar10__weights_8h.html',1,'']]], + ['arm_5fnnexamples_5fgru_2ecpp',['arm_nnexamples_gru.cpp',['../arm__nnexamples__gru_8cpp.html',1,'']]], + ['arm_5fnnexamples_5fgru_5ftest_5fdata_2eh',['arm_nnexamples_gru_test_data.h',['../arm__nnexamples__gru__test__data_8h.html',1,'']]], + ['arm_5fnnfunctions_2eh',['arm_nnfunctions.h',['../arm__nnfunctions_8h.html',1,'']]], + ['arm_5fnnsupportfunctions_2eh',['arm_nnsupportfunctions.h',['../arm__nnsupportfunctions_8h.html',1,'']]], + ['arm_5fnntables_2ec',['arm_nntables.c',['../arm__nntables_8c.html',1,'']]], + ['arm_5fpool_5fq7_5fhwc_2ec',['arm_pool_q7_HWC.c',['../arm__pool__q7__HWC_8c.html',1,'']]], + ['arm_5fq7_5fto_5fq15_5fno_5fshift_2ec',['arm_q7_to_q15_no_shift.c',['../arm__q7__to__q15__no__shift_8c.html',1,'']]], + ['arm_5fq7_5fto_5fq15_5freordered_5fno_5fshift_2ec',['arm_q7_to_q15_reordered_no_shift.c',['../arm__q7__to__q15__reordered__no__shift_8c.html',1,'']]], + ['arm_5frelu_5fq15_2ec',['arm_relu_q15.c',['../arm__relu__q15_8c.html',1,'']]], + ['arm_5frelu_5fq7_2ec',['arm_relu_q7.c',['../arm__relu__q7_8c.html',1,'']]], + ['arm_5fsoftmax_5fq15_2ec',['arm_softmax_q15.c',['../arm__softmax__q15_8c.html',1,'']]], + ['arm_5fsoftmax_5fq7_2ec',['arm_softmax_q7.c',['../arm__softmax__q7_8c.html',1,'']]] +]; diff --git a/docs/NN/html/search/files_1.html b/docs/NN/html/search/files_1.html new file mode 100644 index 0000000..eca1c80 --- /dev/null +++ b/docs/NN/html/search/files_1.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/files_1.js b/docs/NN/html/search/files_1.js new file mode 100644 index 0000000..c17a1ca --- /dev/null +++ b/docs/NN/html/search/files_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['readme_2etxt',['readme.txt',['../cifar10_2readme_8txt.html',1,'']]] +]; diff --git a/docs/NN/html/search/files_2.html b/docs/NN/html/search/files_2.html new file mode 100644 index 0000000..04a8a46 --- /dev/null +++ b/docs/NN/html/search/files_2.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/files_2.js b/docs/NN/html/search/files_2.js new file mode 100644 index 0000000..aaeddfb --- /dev/null +++ b/docs/NN/html/search/files_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['readme_2etxt',['readme.txt',['../gru_2readme_8txt.html',1,'']]] +]; diff --git a/docs/NN/html/search/files_3.html b/docs/NN/html/search/files_3.html new file mode 100644 index 0000000..0dc9a56 --- /dev/null +++ b/docs/NN/html/search/files_3.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/files_3.js b/docs/NN/html/search/files_3.js new file mode 100644 index 0000000..1cdddb0 --- /dev/null +++ b/docs/NN/html/search/files_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['history_2etxt',['history.txt',['../history_8txt.html',1,'']]] +]; diff --git a/docs/NN/html/search/files_4.html b/docs/NN/html/search/files_4.html new file mode 100644 index 0000000..891b5da --- /dev/null +++ b/docs/NN/html/search/files_4.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/files_4.js b/docs/NN/html/search/files_4.js new file mode 100644 index 0000000..29b0c82 --- /dev/null +++ b/docs/NN/html/search/files_4.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['para_5fgen_2epy',['para_gen.py',['../para__gen_8py.html',1,'']]] +]; diff --git a/docs/NN/html/search/functions_0.html b/docs/NN/html/search/functions_0.html new file mode 100644 index 0000000..16a5a52 --- /dev/null +++ b/docs/NN/html/search/functions_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/functions_0.js b/docs/NN/html/search/functions_0.js new file mode 100644 index 0000000..81d0f1f --- /dev/null +++ b/docs/NN/html/search/functions_0.js @@ -0,0 +1,34 @@ +var searchData= +[ + ['arm_5favepool_5fq7_5fhwc',['arm_avepool_q7_HWC',['../group__Pooling.html#gae4a7b07f97ec4313524c9fb9fbcb1f6a',1,'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): arm_pool_q7_HWC.c'],['../group__Pooling.html#gae4a7b07f97ec4313524c9fb9fbcb1f6a',1,'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): arm_pool_q7_HWC.c']]], + ['arm_5fconvolve_5f1x1_5fhwc_5fq7_5ffast_5fnonsquare',['arm_convolve_1x1_HWC_q7_fast_nonsquare',['../group__NNConv.html#ga110adcfdaab356c750c6270aa5e05f29',1,'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): arm_convolve_1x1_HWC_q7_fast_nonsquare.c'],['../group__NNConv.html#ga110adcfdaab356c750c6270aa5e05f29',1,'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): arm_convolve_1x1_HWC_q7_fast_nonsquare.c']]], + ['arm_5fconvolve_5fhwc_5fq15_5fbasic',['arm_convolve_HWC_q15_basic',['../group__NNConv.html#ga55701f213b198084b52eab53097f1f58',1,'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): arm_convolve_HWC_q15_basic.c'],['../group__NNConv.html#ga55701f213b198084b52eab53097f1f58',1,'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): arm_convolve_HWC_q15_basic.c']]], + ['arm_5fconvolve_5fhwc_5fq15_5ffast',['arm_convolve_HWC_q15_fast',['../group__NNConv.html#ga4efb1ccbbaa7dd936961989dcb443f50',1,'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): arm_convolve_HWC_q15_fast.c'],['../group__NNConv.html#ga4efb1ccbbaa7dd936961989dcb443f50',1,'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): arm_convolve_HWC_q15_fast.c']]], + ['arm_5fconvolve_5fhwc_5fq15_5ffast_5fnonsquare',['arm_convolve_HWC_q15_fast_nonsquare',['../group__NNConv.html#ga614ec3b71eb96e29952ec3f09e7b9c3c',1,'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): arm_convolve_HWC_q15_fast_nonsquare.c'],['../group__NNConv.html#ga614ec3b71eb96e29952ec3f09e7b9c3c',1,'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): arm_convolve_HWC_q15_fast_nonsquare.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5fbasic',['arm_convolve_HWC_q7_basic',['../group__NNConv.html#ga210ae8d8fc1d12ee15b41f1fa6947681',1,'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): arm_convolve_HWC_q7_basic.c'],['../group__NNConv.html#ga210ae8d8fc1d12ee15b41f1fa6947681',1,'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): arm_convolve_HWC_q7_basic.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5fbasic_5fnonsquare',['arm_convolve_HWC_q7_basic_nonsquare',['../group__NNConv.html#ga4501fa22c0836002aa47ccc313dce252',1,'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): arm_convolve_HWC_q7_basic_nonsquare.c'],['../group__NNConv.html#ga4501fa22c0836002aa47ccc313dce252',1,'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): arm_convolve_HWC_q7_basic_nonsquare.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5ffast',['arm_convolve_HWC_q7_fast',['../group__NNConv.html#gae00d3c1285907d59657369fc98bcc83f',1,'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): arm_convolve_HWC_q7_fast.c'],['../group__NNConv.html#gae00d3c1285907d59657369fc98bcc83f',1,'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): arm_convolve_HWC_q7_fast.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5ffast_5fnonsquare',['arm_convolve_HWC_q7_fast_nonsquare',['../group__NNConv.html#gabc6d6b991024e9e5c5cdbd7489de88ef',1,'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): arm_convolve_HWC_q7_fast_nonsquare.c'],['../group__NNConv.html#gabc6d6b991024e9e5c5cdbd7489de88ef',1,'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): arm_convolve_HWC_q7_fast_nonsquare.c']]], + ['arm_5fconvolve_5fhwc_5fq7_5frgb',['arm_convolve_HWC_q7_RGB',['../group__NNConv.html#ga98f2ead67d7cbdf558b0cd8a3b8fc148',1,'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): arm_convolve_HWC_q7_RGB.c'],['../group__NNConv.html#ga98f2ead67d7cbdf558b0cd8a3b8fc148',1,'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): arm_convolve_HWC_q7_RGB.c']]], + ['arm_5fdepthwise_5fseparable_5fconv_5fhwc_5fq7',['arm_depthwise_separable_conv_HWC_q7',['../group__NNConv.html#gad3d21b3bc6dbd6f3b97d01104349cb0a',1,'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): arm_depthwise_separable_conv_HWC_q7.c'],['../group__NNConv.html#gad3d21b3bc6dbd6f3b97d01104349cb0a',1,'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): arm_depthwise_separable_conv_HWC_q7.c']]], + ['arm_5fdepthwise_5fseparable_5fconv_5fhwc_5fq7_5fnonsquare',['arm_depthwise_separable_conv_HWC_q7_nonsquare',['../group__NNConv.html#ga32ac508c5467813a84f74f96655dc697',1,'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): arm_depthwise_separable_conv_HWC_q7_nonsquare.c'],['../group__NNConv.html#ga32ac508c5467813a84f74f96655dc697',1,'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): arm_depthwise_separable_conv_HWC_q7_nonsquare.c']]], + ['arm_5ffully_5fconnected_5fmat_5fq7_5fvec_5fq15',['arm_fully_connected_mat_q7_vec_q15',['../group__FC.html#ga4a1521e7532a1e62d71f3b12762016e2',1,'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): arm_fully_connected_mat_q7_vec_q15.c'],['../group__FC.html#ga4a1521e7532a1e62d71f3b12762016e2',1,'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): arm_fully_connected_mat_q7_vec_q15.c']]], + ['arm_5ffully_5fconnected_5fmat_5fq7_5fvec_5fq15_5fopt',['arm_fully_connected_mat_q7_vec_q15_opt',['../group__FC.html#gae3857bb6375692e81dde8cbd70adec08',1,'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): arm_fully_connected_mat_q7_vec_q15_opt.c'],['../group__FC.html#gae3857bb6375692e81dde8cbd70adec08',1,'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): arm_fully_connected_mat_q7_vec_q15_opt.c']]], + ['arm_5ffully_5fconnected_5fq15',['arm_fully_connected_q15',['../group__FC.html#gaac666c212b209e636c2369dd5c75d0dc',1,'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): arm_fully_connected_q15.c'],['../group__FC.html#gaac666c212b209e636c2369dd5c75d0dc',1,'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): arm_fully_connected_q15.c']]], + ['arm_5ffully_5fconnected_5fq15_5fopt',['arm_fully_connected_q15_opt',['../group__FC.html#ga062912078da113f5dd2004fd919a0ff2',1,'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): arm_fully_connected_q15_opt.c'],['../group__FC.html#ga062912078da113f5dd2004fd919a0ff2',1,'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): arm_fully_connected_q15_opt.c']]], + ['arm_5ffully_5fconnected_5fq7',['arm_fully_connected_q7',['../group__FC.html#ga8b7e0c2e989e8c75f0dc789f3115323d',1,'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): arm_fully_connected_q7.c'],['../group__FC.html#ga8b7e0c2e989e8c75f0dc789f3115323d',1,'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): arm_fully_connected_q7.c']]], + ['arm_5ffully_5fconnected_5fq7_5fopt',['arm_fully_connected_q7_opt',['../group__FC.html#gaf82b71ef472a38f8fc9ac414d9d07e67',1,'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): arm_fully_connected_q7_opt.c'],['../group__FC.html#gaf82b71ef472a38f8fc9ac414d9d07e67',1,'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): arm_fully_connected_q7_opt.c']]], + ['arm_5fmaxpool_5fq7_5fhwc',['arm_maxpool_q7_HWC',['../group__Pooling.html#ga99afcdcc61eaf429ab3ee823702e44ce',1,'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): arm_pool_q7_HWC.c'],['../group__Pooling.html#ga99afcdcc61eaf429ab3ee823702e44ce',1,'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): arm_pool_q7_HWC.c']]], + ['arm_5fnn_5factivations_5fdirect_5fq15',['arm_nn_activations_direct_q15',['../group__Acti.html#ga8932b57c8d0ee757511af2d40dcc11e7',1,'arm_nn_activations_direct_q15(q15_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type): arm_nn_activations_q15.c'],['../group__Acti.html#ga8932b57c8d0ee757511af2d40dcc11e7',1,'arm_nn_activations_direct_q15(q15_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type): arm_nn_activations_q15.c']]], + ['arm_5fnn_5factivations_5fdirect_5fq7',['arm_nn_activations_direct_q7',['../group__Acti.html#ga79f11131ae6767d60e03b1f6506b1af8',1,'arm_nn_activations_direct_q7(q7_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type): arm_nn_activations_q7.c'],['../group__Acti.html#ga79f11131ae6767d60e03b1f6506b1af8',1,'arm_nn_activations_direct_q7(q7_t *data, uint16_t size, uint16_t int_width, arm_nn_activation_type type): arm_nn_activations_q7.c']]], + ['arm_5fnn_5fmat_5fmult_5fkernel_5fq7_5fq15',['arm_nn_mat_mult_kernel_q7_q15',['../arm__nnfunctions_8h.html#abc4fb258cfe8500ee68e812a293a80a3',1,'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): arm_nn_mat_mult_kernel_q7_q15.c'],['../arm__nn__mat__mult__kernel__q7__q15_8c.html#abc4fb258cfe8500ee68e812a293a80a3',1,'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): arm_nn_mat_mult_kernel_q7_q15.c']]], + ['arm_5fnn_5fmat_5fmult_5fkernel_5fq7_5fq15_5freordered',['arm_nn_mat_mult_kernel_q7_q15_reordered',['../arm__nnfunctions_8h.html#aefe9c7ce9a65060a244b06dffe74c4b3',1,'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): arm_nn_mat_mult_kernel_q7_q15_reordered.c'],['../arm__nn__mat__mult__kernel__q7__q15__reordered_8c.html#aefe9c7ce9a65060a244b06dffe74c4b3',1,'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): arm_nn_mat_mult_kernel_q7_q15_reordered.c']]], + ['arm_5fnn_5fmult_5fq15',['arm_nn_mult_q15',['../group__NNBasicMath.html#ga08f8340aa6533271b3aa6d211614fe22',1,'arm_nn_mult_q15(q15_t *pSrcA, q15_t *pSrcB, q15_t *pDst, const uint16_t out_shift, uint32_t blockSize): arm_nn_mult_q15.c'],['../group__NNBasicMath.html#ga08f8340aa6533271b3aa6d211614fe22',1,'arm_nn_mult_q15(q15_t *pSrcA, q15_t *pSrcB, q15_t *pDst, const uint16_t out_shift, uint32_t blockSize): arm_nn_mult_q15.c']]], + ['arm_5fnn_5fmult_5fq7',['arm_nn_mult_q7',['../group__NNBasicMath.html#gad46c9ab012cceda8ce6681c687a58c70',1,'arm_nn_mult_q7(q7_t *pSrcA, q7_t *pSrcB, q7_t *pDst, const uint16_t out_shift, uint32_t blockSize): arm_nn_mult_q7.c'],['../group__NNBasicMath.html#gad46c9ab012cceda8ce6681c687a58c70',1,'arm_nn_mult_q7(q7_t *pSrcA, q7_t *pSrcB, q7_t *pDst, const uint16_t out_shift, uint32_t blockSize): arm_nn_mult_q7.c']]], + ['arm_5fq7_5fto_5fq15_5fno_5fshift',['arm_q7_to_q15_no_shift',['../group__nndata__convert.html#gae349de4dba8d253c89d45794ccf05680',1,'arm_q7_to_q15_no_shift(const q7_t *pSrc, q15_t *pDst, uint32_t blockSize): arm_q7_to_q15_no_shift.c'],['../group__nndata__convert.html#gae349de4dba8d253c89d45794ccf05680',1,'arm_q7_to_q15_no_shift(const q7_t *pSrc, q15_t *pDst, uint32_t blockSize): arm_q7_to_q15_no_shift.c']]], + ['arm_5fq7_5fto_5fq15_5freordered_5fno_5fshift',['arm_q7_to_q15_reordered_no_shift',['../group__nndata__convert.html#gaba8fd446d5f54760b406ee63b25d1aee',1,'arm_q7_to_q15_reordered_no_shift(const q7_t *pSrc, q15_t *pDst, uint32_t blockSize): arm_q7_to_q15_reordered_no_shift.c'],['../group__nndata__convert.html#gaba8fd446d5f54760b406ee63b25d1aee',1,'arm_q7_to_q15_reordered_no_shift(const q7_t *pSrc, q15_t *pDst, uint32_t blockSize): arm_q7_to_q15_reordered_no_shift.c']]], + ['arm_5frelu_5fq15',['arm_relu_q15',['../group__Acti.html#ga53bcc00e54b802919bb3c89c143ee5ba',1,'arm_relu_q15(q15_t *data, uint16_t size): arm_relu_q15.c'],['../group__Acti.html#ga53bcc00e54b802919bb3c89c143ee5ba',1,'arm_relu_q15(q15_t *data, uint16_t size): arm_relu_q15.c']]], + ['arm_5frelu_5fq7',['arm_relu_q7',['../group__Acti.html#ga638e803b4fe00426f401783a6255ca30',1,'arm_relu_q7(q7_t *data, uint16_t size): arm_relu_q7.c'],['../group__Acti.html#ga638e803b4fe00426f401783a6255ca30',1,'arm_relu_q7(q7_t *data, uint16_t size): arm_relu_q7.c']]], + ['arm_5fsoftmax_5fq15',['arm_softmax_q15',['../group__Softmax.html#ga1cacd8b84b8363079311987d0016ebe5',1,'arm_softmax_q15(const q15_t *vec_in, const uint16_t dim_vec, q15_t *p_out): arm_softmax_q15.c'],['../group__Softmax.html#ga1cacd8b84b8363079311987d0016ebe5',1,'arm_softmax_q15(const q15_t *vec_in, const uint16_t dim_vec, q15_t *p_out): arm_softmax_q15.c']]], + ['arm_5fsoftmax_5fq7',['arm_softmax_q7',['../group__Softmax.html#ga89aff212a97a3cf32d9d7ddf11a8f43e',1,'arm_softmax_q7(const q7_t *vec_in, const uint16_t dim_vec, q7_t *p_out): arm_softmax_q7.c'],['../group__Softmax.html#ga89aff212a97a3cf32d9d7ddf11a8f43e',1,'arm_softmax_q7(const q7_t *vec_in, const uint16_t dim_vec, q7_t *p_out): arm_softmax_q7.c']]] +]; diff --git a/docs/NN/html/search/functions_1.html b/docs/NN/html/search/functions_1.html new file mode 100644 index 0000000..3b4eacf --- /dev/null +++ b/docs/NN/html/search/functions_1.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/functions_1.js b/docs/NN/html/search/functions_1.js new file mode 100644 index 0000000..8d250c5 --- /dev/null +++ b/docs/NN/html/search/functions_1.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['convert_5fq7_5fq15_5fweights',['convert_q7_q15_weights',['../namespacepara__gen.html#a75db0b43a1b942aa87ff10fd3b73dc8d',1,'para_gen']]], + ['convert_5fto_5fx4_5fweights',['convert_to_x4_weights',['../namespacepara__gen.html#ab7f5de20ae32542da9f83a8e99850722',1,'para_gen']]] +]; diff --git a/docs/NN/html/search/functions_2.html b/docs/NN/html/search/functions_2.html new file mode 100644 index 0000000..78be8b4 --- /dev/null +++ b/docs/NN/html/search/functions_2.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/functions_2.js b/docs/NN/html/search/functions_2.js new file mode 100644 index 0000000..b07aef4 --- /dev/null +++ b/docs/NN/html/search/functions_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['gru_5fexample',['gru_example',['../arm__nnexamples__gru_8cpp.html#ac71a806472c7c0c284a2253e71a6a27b',1,'arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/functions_3.html b/docs/NN/html/search/functions_3.html new file mode 100644 index 0000000..ebf2eeb --- /dev/null +++ b/docs/NN/html/search/functions_3.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/functions_3.js b/docs/NN/html/search/functions_3.js new file mode 100644 index 0000000..5bb2b40 --- /dev/null +++ b/docs/NN/html/search/functions_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['main',['main',['../arm__nnexamples__cifar10_8cpp.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__gru_8cpp.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main(): arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/groups_0.html b/docs/NN/html/search/groups_0.html new file mode 100644 index 0000000..2090afa --- /dev/null +++ b/docs/NN/html/search/groups_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/groups_0.js b/docs/NN/html/search/groups_0.js new file mode 100644 index 0000000..ba383cb --- /dev/null +++ b/docs/NN/html/search/groups_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['basic_20math_20functions_20for_20neural_20network_20computation',['Basic Math Functions for Neural Network Computation',['../group__NNBasicMath.html',1,'']]] +]; diff --git a/docs/NN/html/search/groups_1.html b/docs/NN/html/search/groups_1.html new file mode 100644 index 0000000..3ad8a3b --- /dev/null +++ b/docs/NN/html/search/groups_1.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/groups_1.js b/docs/NN/html/search/groups_1.js new file mode 100644 index 0000000..e3787bc --- /dev/null +++ b/docs/NN/html/search/groups_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['convolutional_20neural_20network_20example',['Convolutional Neural Network Example',['../group__CNNExample.html',1,'']]] +]; diff --git a/docs/NN/html/search/groups_2.html b/docs/NN/html/search/groups_2.html new file mode 100644 index 0000000..361832c --- /dev/null +++ b/docs/NN/html/search/groups_2.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/groups_2.js b/docs/NN/html/search/groups_2.js new file mode 100644 index 0000000..4a44fa7 --- /dev/null +++ b/docs/NN/html/search/groups_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['fully_2dconnected_20layer_20functions',['Fully-connected Layer Functions',['../group__FC.html',1,'']]] +]; diff --git a/docs/NN/html/search/groups_3.html b/docs/NN/html/search/groups_3.html new file mode 100644 index 0000000..f42200a --- /dev/null +++ b/docs/NN/html/search/groups_3.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/groups_3.js b/docs/NN/html/search/groups_3.js new file mode 100644 index 0000000..65fb309 --- /dev/null +++ b/docs/NN/html/search/groups_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['gated_20recurrent_20unit_20example',['Gated Recurrent Unit Example',['../group__GRUExample.html',1,'']]] +]; diff --git a/docs/NN/html/search/groups_4.html b/docs/NN/html/search/groups_4.html new file mode 100644 index 0000000..b07fdf9 --- /dev/null +++ b/docs/NN/html/search/groups_4.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/groups_4.js b/docs/NN/html/search/groups_4.js new file mode 100644 index 0000000..9de9a65 --- /dev/null +++ b/docs/NN/html/search/groups_4.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['neural_20network_20activation_20functions',['Neural Network Activation Functions',['../group__Acti.html',1,'']]], + ['neural_20network_20functions',['Neural Network Functions',['../group__groupNN.html',1,'']]], + ['neural_20network_20convolution_20functions',['Neural Network Convolution Functions',['../group__NNConv.html',1,'']]], + ['neural_20network_20data_20conversion_20functions',['Neural Network Data Conversion Functions',['../group__nndata__convert.html',1,'']]], + ['neural_20network_20pooling_20functions',['Neural Network Pooling Functions',['../group__Pooling.html',1,'']]] +]; diff --git a/docs/NN/html/search/groups_5.html b/docs/NN/html/search/groups_5.html new file mode 100644 index 0000000..35324c0 --- /dev/null +++ b/docs/NN/html/search/groups_5.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/groups_5.js b/docs/NN/html/search/groups_5.js new file mode 100644 index 0000000..a192cd1 --- /dev/null +++ b/docs/NN/html/search/groups_5.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['softmax_20functions',['Softmax Functions',['../group__Softmax.html',1,'']]] +]; diff --git a/docs/NN/html/search/mag_sel.png b/docs/NN/html/search/mag_sel.png new file mode 100644 index 0000000..81f6040 Binary files /dev/null and b/docs/NN/html/search/mag_sel.png differ diff --git a/docs/NN/html/search/namespaces_0.html b/docs/NN/html/search/namespaces_0.html new file mode 100644 index 0000000..dc60686 --- /dev/null +++ b/docs/NN/html/search/namespaces_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/namespaces_0.js b/docs/NN/html/search/namespaces_0.js new file mode 100644 index 0000000..f7ae612 --- /dev/null +++ b/docs/NN/html/search/namespaces_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['para_5fgen',['para_gen',['../namespacepara__gen.html',1,'']]] +]; diff --git a/docs/NN/html/search/nomatches.html b/docs/NN/html/search/nomatches.html new file mode 100644 index 0000000..b1ded27 --- /dev/null +++ b/docs/NN/html/search/nomatches.html @@ -0,0 +1,12 @@ + + + + + + + +
    +
    No Matches
    +
    + + diff --git a/docs/NN/html/search/pages_0.html b/docs/NN/html/search/pages_0.html new file mode 100644 index 0000000..c51c834 --- /dev/null +++ b/docs/NN/html/search/pages_0.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/pages_0.js b/docs/NN/html/search/pages_0.js new file mode 100644 index 0000000..09b85a4 --- /dev/null +++ b/docs/NN/html/search/pages_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['cmsis_20nn_20software_20library',['CMSIS NN Software Library',['../index.html',1,'']]] +]; diff --git a/docs/NN/html/search/pages_1.html b/docs/NN/html/search/pages_1.html new file mode 100644 index 0000000..2a98fce --- /dev/null +++ b/docs/NN/html/search/pages_1.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/pages_1.js b/docs/NN/html/search/pages_1.js new file mode 100644 index 0000000..ed3f118 --- /dev/null +++ b/docs/NN/html/search/pages_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['revision_20history_20of_20cmsis_2dnn',['Revision History of CMSIS-NN',['../ChangeLog_pg.html',1,'']]] +]; diff --git a/docs/NN/html/search/search.css b/docs/NN/html/search/search.css new file mode 100644 index 0000000..1746d13 --- /dev/null +++ b/docs/NN/html/search/search.css @@ -0,0 +1,240 @@ +/*---------------- Search Box */ + +#FSearchBox { + float: left; +} + +#searchli { + float: right; + display: block; + width: 170px; + height: 24px; +} + +#MSearchBox { + white-space : nowrap; + position: absolute; + float: none; + display: inline; + margin-top: 3px; + right: 0px; + width: 170px; + z-index: 102; +} + +#MSearchBox .left +{ + display:block; + position:absolute; + left:10px; + width:20px; + height:19px; + background:url('search_l.png') no-repeat; + background-position:right; +} + +#MSearchSelect { + display:block; + position:absolute; + width:20px; + height:19px; +} + +.left #MSearchSelect { + left:4px; +} + +.right #MSearchSelect { + right:5px; +} + +#MSearchField { + display:block; + position:absolute; + height:19px; + background:url('search_m.png') repeat-x; + border:none; + width:116px; + margin-left:20px; + padding-left:4px; + color: #909090; + outline: none; + font: 9pt Arial, Verdana, sans-serif; +} + +#FSearchBox #MSearchField { + margin-left:15px; +} + +#MSearchBox .right { + display:block; + position:absolute; + right:10px; + top:0px; + width:20px; + height:19px; + background:url('search_r.png') no-repeat; + background-position:left; +} + +#MSearchClose { + display: none; + position: absolute; + top: 4px; + background : none; + border: none; + margin: 0px 4px 0px 0px; + padding: 0px 0px; + outline: none; +} + +.left #MSearchClose { + left: 6px; +} + +.right #MSearchClose { + right: 2px; +} + +.MSearchBoxActive #MSearchField { + color: #000000; +} + +/*---------------- Search filter selection */ + +#MSearchSelectWindow { + display: none; + position: absolute; + left: 0; top: 0; + border: 1px solid #90A5CE; + background-color: #F9FAFC; + z-index: 1; + padding-top: 4px; + padding-bottom: 4px; + -moz-border-radius: 4px; + -webkit-border-top-left-radius: 4px; + -webkit-border-top-right-radius: 4px; + -webkit-border-bottom-left-radius: 4px; + -webkit-border-bottom-right-radius: 4px; + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); +} + +.SelectItem { + font: 8pt Arial, Verdana, sans-serif; + padding-left: 2px; + padding-right: 12px; + border: 0px; +} + +span.SelectionMark { + margin-right: 4px; + font-family: monospace; + outline-style: none; + text-decoration: none; +} + +a.SelectItem { + display: block; + outline-style: none; + color: #000000; + text-decoration: none; + padding-left: 6px; + padding-right: 12px; +} + +a.SelectItem:focus, +a.SelectItem:active { + color: #000000; + outline-style: none; + text-decoration: none; +} + +a.SelectItem:hover { + color: #FFFFFF; + background-color: #3D578C; + outline-style: none; + text-decoration: none; + cursor: pointer; + display: block; +} + +/*---------------- Search results window */ + +iframe#MSearchResults { + width: 60ex; + height: 15em; +} + +#MSearchResultsWindow { + display: none; + position: absolute; + left: 0; top: 0; + border: 1px solid #000; + background-color: #EEF1F7; +} + +/* ----------------------------------- */ + + +#SRIndex { + clear:both; + padding-bottom: 15px; +} + +.SREntry { + font-size: 10pt; + padding-left: 1ex; +} + +.SRPage .SREntry { + font-size: 8pt; + padding: 1px 5px; +} + +body.SRPage { + margin: 5px 2px; +} + +.SRChildren { + padding-left: 3ex; padding-bottom: .5em +} + +.SRPage .SRChildren { + display: none; +} + +.SRSymbol { + font-weight: bold; + color: #425E97; + font-family: Arial, Verdana, sans-serif; + text-decoration: none; + outline: none; +} + +a.SRScope { + display: block; + color: #425E97; + font-family: Arial, Verdana, sans-serif; + text-decoration: none; + outline: none; +} + +a.SRSymbol:focus, a.SRSymbol:active, +a.SRScope:focus, a.SRScope:active { + text-decoration: underline; +} + +.SRPage .SRStatus { + padding: 2px 5px; + font-size: 8pt; + font-style: italic; +} + +.SRResult { + display: none; +} + +DIV.searchresults { + margin-left: 10px; + margin-right: 10px; +} diff --git a/docs/NN/html/search/search.js b/docs/NN/html/search/search.js new file mode 100644 index 0000000..8917d65 --- /dev/null +++ b/docs/NN/html/search/search.js @@ -0,0 +1,813 @@ +// Search script generated by doxygen +// Copyright (C) 2009 by Dimitri van Heesch. + +// The code in this file is loosly based on main.js, part of Natural Docs, +// which is Copyright (C) 2003-2008 Greg Valure +// Natural Docs is licensed under the GPL. + +var indexSectionsWithContent = +{ + 0: "abcdfghimnoprstuvw", + 1: "a", + 2: "p", + 3: "acghp", + 4: "acgm", + 5: "bchinorstuvw", + 6: "a", + 7: "a", + 8: "cdhinpru", + 9: "bcfgns", + 10: "cr" +}; + +var indexSectionNames = +{ + 0: "all", + 1: "classes", + 2: "namespaces", + 3: "files", + 4: "functions", + 5: "variables", + 6: "enums", + 7: "enumvalues", + 8: "defines", + 9: "groups", + 10: "pages" +}; + +function convertToId(search) +{ + var result = ''; + for (i=0;i do a search + { + this.Search(); + } + } + + this.OnSearchSelectKey = function(evt) + { + var e = (evt) ? evt : window.event; // for IE + if (e.keyCode==40 && this.searchIndex0) // Up + { + this.searchIndex--; + this.OnSelectItem(this.searchIndex); + } + else if (e.keyCode==13 || e.keyCode==27) + { + this.OnSelectItem(this.searchIndex); + this.CloseSelectionWindow(); + this.DOMSearchField().focus(); + } + return false; + } + + // --------- Actions + + // Closes the results window. + this.CloseResultsWindow = function() + { + this.DOMPopupSearchResultsWindow().style.display = 'none'; + this.DOMSearchClose().style.display = 'none'; + this.Activate(false); + } + + this.CloseSelectionWindow = function() + { + this.DOMSearchSelectWindow().style.display = 'none'; + } + + // Performs a search. + this.Search = function() + { + this.keyTimeout = 0; + + // strip leading whitespace + var searchValue = this.DOMSearchField().value.replace(/^ +/, ""); + + var code = searchValue.toLowerCase().charCodeAt(0); + var idxChar = searchValue.substr(0, 1).toLowerCase(); + if ( 0xD800 <= code && code <= 0xDBFF && searchValue > 1) // surrogate pair + { + idxChar = searchValue.substr(0, 2); + } + + var resultsPage; + var resultsPageWithSearch; + var hasResultsPage; + + var idx = indexSectionsWithContent[this.searchIndex].indexOf(idxChar); + if (idx!=-1) + { + var hexCode=idx.toString(16); + resultsPage = this.resultsPath + '/' + indexSectionNames[this.searchIndex] + '_' + hexCode + '.html'; + resultsPageWithSearch = resultsPage+'?'+escape(searchValue); + hasResultsPage = true; + } + else // nothing available for this search term + { + resultsPage = this.resultsPath + '/nomatches.html'; + resultsPageWithSearch = resultsPage; + hasResultsPage = false; + } + + window.frames.MSearchResults.location = resultsPageWithSearch; + var domPopupSearchResultsWindow = this.DOMPopupSearchResultsWindow(); + + if (domPopupSearchResultsWindow.style.display!='block') + { + var domSearchBox = this.DOMSearchBox(); + this.DOMSearchClose().style.display = 'inline'; + if (this.insideFrame) + { + var domPopupSearchResults = this.DOMPopupSearchResults(); + domPopupSearchResultsWindow.style.position = 'relative'; + domPopupSearchResultsWindow.style.display = 'block'; + var width = document.body.clientWidth - 8; // the -8 is for IE :-( + domPopupSearchResultsWindow.style.width = width + 'px'; + domPopupSearchResults.style.width = width + 'px'; + } + else + { + var domPopupSearchResults = this.DOMPopupSearchResults(); + var left = getXPos(domSearchBox) + 150; // domSearchBox.offsetWidth; + var top = getYPos(domSearchBox) + 20; // domSearchBox.offsetHeight + 1; + domPopupSearchResultsWindow.style.display = 'block'; + left -= domPopupSearchResults.offsetWidth; + domPopupSearchResultsWindow.style.top = top + 'px'; + domPopupSearchResultsWindow.style.left = left + 'px'; + } + } + + this.lastSearchValue = searchValue; + this.lastResultsPage = resultsPage; + } + + // -------- Activation Functions + + // Activates or deactivates the search panel, resetting things to + // their default values if necessary. + this.Activate = function(isActive) + { + if (isActive || // open it + this.DOMPopupSearchResultsWindow().style.display == 'block' + ) + { + this.DOMSearchBox().className = 'MSearchBoxActive'; + + var searchField = this.DOMSearchField(); + + if (searchField.value == this.searchLabel) // clear "Search" term upon entry + { + searchField.value = ''; + this.searchActive = true; + } + } + else if (!isActive) // directly remove the panel + { + this.DOMSearchBox().className = 'MSearchBoxInactive'; + this.DOMSearchField().value = this.searchLabel; + this.searchActive = false; + this.lastSearchValue = '' + this.lastResultsPage = ''; + } + } +} + +// ----------------------------------------------------------------------- + +// The class that handles everything on the search results page. +function SearchResults(name) +{ + // The number of matches from the last run of . + this.lastMatchCount = 0; + this.lastKey = 0; + this.repeatOn = false; + + // Toggles the visibility of the passed element ID. + this.FindChildElement = function(id) + { + var parentElement = document.getElementById(id); + var element = parentElement.firstChild; + + while (element && element!=parentElement) + { + if (element.nodeName == 'DIV' && element.className == 'SRChildren') + { + return element; + } + + if (element.nodeName == 'DIV' && element.hasChildNodes()) + { + element = element.firstChild; + } + else if (element.nextSibling) + { + element = element.nextSibling; + } + else + { + do + { + element = element.parentNode; + } + while (element && element!=parentElement && !element.nextSibling); + + if (element && element!=parentElement) + { + element = element.nextSibling; + } + } + } + } + + this.Toggle = function(id) + { + var element = this.FindChildElement(id); + if (element) + { + if (element.style.display == 'block') + { + element.style.display = 'none'; + } + else + { + element.style.display = 'block'; + } + } + } + + // Searches for the passed string. If there is no parameter, + // it takes it from the URL query. + // + // Always returns true, since other documents may try to call it + // and that may or may not be possible. + this.Search = function(search) + { + if (!search) // get search word from URL + { + search = window.location.search; + search = search.substring(1); // Remove the leading '?' + search = unescape(search); + } + + search = search.replace(/^ +/, ""); // strip leading spaces + search = search.replace(/ +$/, ""); // strip trailing spaces + search = search.toLowerCase(); + search = convertToId(search); + + var resultRows = document.getElementsByTagName("div"); + var matches = 0; + + var i = 0; + while (i < resultRows.length) + { + var row = resultRows.item(i); + if (row.className == "SRResult") + { + var rowMatchName = row.id.toLowerCase(); + rowMatchName = rowMatchName.replace(/^sr\d*_/, ''); // strip 'sr123_' + + if (search.length<=rowMatchName.length && + rowMatchName.substr(0, search.length)==search) + { + row.style.display = 'block'; + matches++; + } + else + { + row.style.display = 'none'; + } + } + i++; + } + document.getElementById("Searching").style.display='none'; + if (matches == 0) // no results + { + document.getElementById("NoMatches").style.display='block'; + } + else // at least one result + { + document.getElementById("NoMatches").style.display='none'; + } + this.lastMatchCount = matches; + return true; + } + + // return the first item with index index or higher that is visible + this.NavNext = function(index) + { + var focusItem; + while (1) + { + var focusName = 'Item'+index; + focusItem = document.getElementById(focusName); + if (focusItem && focusItem.parentNode.parentNode.style.display=='block') + { + break; + } + else if (!focusItem) // last element + { + break; + } + focusItem=null; + index++; + } + return focusItem; + } + + this.NavPrev = function(index) + { + var focusItem; + while (1) + { + var focusName = 'Item'+index; + focusItem = document.getElementById(focusName); + if (focusItem && focusItem.parentNode.parentNode.style.display=='block') + { + break; + } + else if (!focusItem) // last element + { + break; + } + focusItem=null; + index--; + } + return focusItem; + } + + this.ProcessKeys = function(e) + { + if (e.type == "keydown") + { + this.repeatOn = false; + this.lastKey = e.keyCode; + } + else if (e.type == "keypress") + { + if (!this.repeatOn) + { + if (this.lastKey) this.repeatOn = true; + return false; // ignore first keypress after keydown + } + } + else if (e.type == "keyup") + { + this.lastKey = 0; + this.repeatOn = false; + } + return this.lastKey!=0; + } + + this.Nav = function(evt,itemIndex) + { + var e = (evt) ? evt : window.event; // for IE + if (e.keyCode==13) return true; + if (!this.ProcessKeys(e)) return false; + + if (this.lastKey==38) // Up + { + var newIndex = itemIndex-1; + var focusItem = this.NavPrev(newIndex); + if (focusItem) + { + var child = this.FindChildElement(focusItem.parentNode.parentNode.id); + if (child && child.style.display == 'block') // children visible + { + var n=0; + var tmpElem; + while (1) // search for last child + { + tmpElem = document.getElementById('Item'+newIndex+'_c'+n); + if (tmpElem) + { + focusItem = tmpElem; + } + else // found it! + { + break; + } + n++; + } + } + } + if (focusItem) + { + focusItem.focus(); + } + else // return focus to search field + { + parent.document.getElementById("MSearchField").focus(); + } + } + else if (this.lastKey==40) // Down + { + var newIndex = itemIndex+1; + var focusItem; + var item = document.getElementById('Item'+itemIndex); + var elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem && elem.style.display == 'block') // children visible + { + focusItem = document.getElementById('Item'+itemIndex+'_c0'); + } + if (!focusItem) focusItem = this.NavNext(newIndex); + if (focusItem) focusItem.focus(); + } + else if (this.lastKey==39) // Right + { + var item = document.getElementById('Item'+itemIndex); + var elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem) elem.style.display = 'block'; + } + else if (this.lastKey==37) // Left + { + var item = document.getElementById('Item'+itemIndex); + var elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem) elem.style.display = 'none'; + } + else if (this.lastKey==27) // Escape + { + parent.searchBox.CloseResultsWindow(); + parent.document.getElementById("MSearchField").focus(); + } + else if (this.lastKey==13) // Enter + { + return true; + } + return false; + } + + this.NavChild = function(evt,itemIndex,childIndex) + { + var e = (evt) ? evt : window.event; // for IE + if (e.keyCode==13) return true; + if (!this.ProcessKeys(e)) return false; + + if (this.lastKey==38) // Up + { + if (childIndex>0) + { + var newIndex = childIndex-1; + document.getElementById('Item'+itemIndex+'_c'+newIndex).focus(); + } + else // already at first child, jump to parent + { + document.getElementById('Item'+itemIndex).focus(); + } + } + else if (this.lastKey==40) // Down + { + var newIndex = childIndex+1; + var elem = document.getElementById('Item'+itemIndex+'_c'+newIndex); + if (!elem) // last child, jump to parent next parent + { + elem = this.NavNext(itemIndex+1); + } + if (elem) + { + elem.focus(); + } + } + else if (this.lastKey==27) // Escape + { + parent.searchBox.CloseResultsWindow(); + parent.document.getElementById("MSearchField").focus(); + } + else if (this.lastKey==13) // Enter + { + return true; + } + return false; + } +} + +function setKeyActions(elem,action) +{ + elem.setAttribute('onkeydown',action); + elem.setAttribute('onkeypress',action); + elem.setAttribute('onkeyup',action); +} + +function setClassAttr(elem,attr) +{ + elem.setAttribute('class',attr); + elem.setAttribute('className',attr); +} + +function createResults() +{ + var results = document.getElementById("SRResults"); + for (var e=0; e + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_0.js b/docs/NN/html/search/variables_0.js new file mode 100644 index 0000000..47c9b57 --- /dev/null +++ b/docs/NN/html/search/variables_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['bytes',['bytes',['../unionarm__nnword.html#ac7cff6480a8e29d95f29b73cb1267249',1,'arm_nnword']]] +]; diff --git a/docs/NN/html/search/variables_1.html b/docs/NN/html/search/variables_1.html new file mode 100644 index 0000000..78f63cd --- /dev/null +++ b/docs/NN/html/search/variables_1.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_1.js b/docs/NN/html/search/variables_1.js new file mode 100644 index 0000000..fe8c679 --- /dev/null +++ b/docs/NN/html/search/variables_1.js @@ -0,0 +1,10 @@ +var searchData= +[ + ['col_5fbuffer',['col_buffer',['../arm__nnexamples__cifar10_8cpp.html#a1f988afc6d7fe29ded1eafbf79a70386',1,'arm_nnexamples_cifar10.cpp']]], + ['conv1_5fbias',['conv1_bias',['../arm__nnexamples__cifar10_8cpp.html#a2dd28923edd6ae13ec6e61e1d876650c',1,'arm_nnexamples_cifar10.cpp']]], + ['conv1_5fwt',['conv1_wt',['../arm__nnexamples__cifar10_8cpp.html#a230b7412ffaaa297340ddcb49c828b4b',1,'arm_nnexamples_cifar10.cpp']]], + ['conv2_5fbias',['conv2_bias',['../arm__nnexamples__cifar10_8cpp.html#a686e558e4de77f778c775c9f0c9866d0',1,'arm_nnexamples_cifar10.cpp']]], + ['conv2_5fwt',['conv2_wt',['../arm__nnexamples__cifar10_8cpp.html#a52875a8218c39da056e6d5bfb2030230',1,'arm_nnexamples_cifar10.cpp']]], + ['conv3_5fbias',['conv3_bias',['../arm__nnexamples__cifar10_8cpp.html#a70b571cac288e0d371eb9f5e7c3ccbdd',1,'arm_nnexamples_cifar10.cpp']]], + ['conv3_5fwt',['conv3_wt',['../arm__nnexamples__cifar10_8cpp.html#a174a146d0ffaa32b073c84d95c489fed',1,'arm_nnexamples_cifar10.cpp']]] +]; diff --git a/docs/NN/html/search/variables_2.html b/docs/NN/html/search/variables_2.html new file mode 100644 index 0000000..ea80d20 --- /dev/null +++ b/docs/NN/html/search/variables_2.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_2.js b/docs/NN/html/search/variables_2.js new file mode 100644 index 0000000..51c8e10 --- /dev/null +++ b/docs/NN/html/search/variables_2.js @@ -0,0 +1,9 @@ +var searchData= +[ + ['half_5fwords',['half_words',['../unionarm__nnword.html#a9b5e49e4e2c4b7203e07b305386bb2ba',1,'arm_nnword']]], + ['hidden_5fbias',['hidden_bias',['../namespacepara__gen.html#a0f6c4400e131b103d2fd89e420d6c308',1,'para_gen']]], + ['hidden_5fstate_5fbias',['hidden_state_bias',['../arm__nnexamples__gru_8cpp.html#a40dda695923891899cb86b2f01bfd98a',1,'arm_nnexamples_gru.cpp']]], + ['hidden_5fstate_5fweights',['hidden_state_weights',['../arm__nnexamples__gru_8cpp.html#ab18783e8d8449d7222ec4a64dfcc92e6',1,'arm_nnexamples_gru.cpp']]], + ['hidden_5fweight',['hidden_weight',['../namespacepara__gen.html#a1a6edb73b72a6bbf443e6e450186660c',1,'para_gen']]], + ['history_5fdata',['history_data',['../namespacepara__gen.html#acdb294668ecca9a6f849afa4156883cd',1,'para_gen']]] +]; diff --git a/docs/NN/html/search/variables_3.html b/docs/NN/html/search/variables_3.html new file mode 100644 index 0000000..0dca26f --- /dev/null +++ b/docs/NN/html/search/variables_3.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_3.js b/docs/NN/html/search/variables_3.js new file mode 100644 index 0000000..4c661a3 --- /dev/null +++ b/docs/NN/html/search/variables_3.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['image_5fdata',['image_data',['../arm__nnexamples__cifar10_8cpp.html#aafa3e1726dde028f2dcce4febc1e9197',1,'arm_nnexamples_cifar10.cpp']]], + ['input_5fdata1',['input_data1',['../namespacepara__gen.html#a845220c0c6574ced6cdaf7b1d2983d6d',1,'para_gen']]], + ['input_5fdata2',['input_data2',['../namespacepara__gen.html#acb820c3015e6a212ad2fe82f7939965a',1,'para_gen']]], + ['ip1_5fbias',['ip1_bias',['../arm__nnexamples__cifar10_8cpp.html#af715ce48798db09f3bed1753fed5c5fb',1,'arm_nnexamples_cifar10.cpp']]], + ['ip1_5fwt',['ip1_wt',['../arm__nnexamples__cifar10_8cpp.html#a244dc5b6679b33a0a85b55adbe969208',1,'arm_nnexamples_cifar10.cpp']]] +]; diff --git a/docs/NN/html/search/variables_4.html b/docs/NN/html/search/variables_4.html new file mode 100644 index 0000000..400e8e9 --- /dev/null +++ b/docs/NN/html/search/variables_4.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_4.js b/docs/NN/html/search/variables_4.js new file mode 100644 index 0000000..8b05fd8 --- /dev/null +++ b/docs/NN/html/search/variables_4.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['new_5fweight',['new_weight',['../namespacepara__gen.html#aead9af07b473ce5bbd93619e3319355c',1,'para_gen']]] +]; diff --git a/docs/NN/html/search/variables_5.html b/docs/NN/html/search/variables_5.html new file mode 100644 index 0000000..7f1241f --- /dev/null +++ b/docs/NN/html/search/variables_5.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_5.js b/docs/NN/html/search/variables_5.js new file mode 100644 index 0000000..60ee6dc --- /dev/null +++ b/docs/NN/html/search/variables_5.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['outfile',['outfile',['../namespacepara__gen.html#a2e1a6685422a591fcb7801e9fd8ad574',1,'para_gen']]], + ['output_5fdata',['output_data',['../arm__nnexamples__cifar10_8cpp.html#a75c8e3727f7d3637f03ffb1d9f727313',1,'arm_nnexamples_cifar10.cpp']]] +]; diff --git a/docs/NN/html/search/variables_6.html b/docs/NN/html/search/variables_6.html new file mode 100644 index 0000000..7536df8 --- /dev/null +++ b/docs/NN/html/search/variables_6.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_6.js b/docs/NN/html/search/variables_6.js new file mode 100644 index 0000000..e726ec5 --- /dev/null +++ b/docs/NN/html/search/variables_6.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['reset_5fbias',['reset_bias',['../namespacepara__gen.html#a3da798c88974b5d760f3e97288a0c490',1,'para_gen']]], + ['reset_5fgate_5fbias',['reset_gate_bias',['../arm__nnexamples__gru_8cpp.html#a2a9d5c9f16ee778ecc8170d8664722c7',1,'arm_nnexamples_gru.cpp']]], + ['reset_5fgate_5fweights',['reset_gate_weights',['../arm__nnexamples__gru_8cpp.html#ac2ae1ff19167c2bb359db2b319ca1060',1,'arm_nnexamples_gru.cpp']]], + ['reset_5fweight',['reset_weight',['../namespacepara__gen.html#a4ebba057829420c878a0a29ee9c71582',1,'para_gen']]], + ['row_5fdim',['row_dim',['../namespacepara__gen.html#a26cc0a96186b2e6b238d783d9364f14d',1,'para_gen']]] +]; diff --git a/docs/NN/html/search/variables_7.html b/docs/NN/html/search/variables_7.html new file mode 100644 index 0000000..66186a6 --- /dev/null +++ b/docs/NN/html/search/variables_7.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_7.js b/docs/NN/html/search/variables_7.js new file mode 100644 index 0000000..7429444 --- /dev/null +++ b/docs/NN/html/search/variables_7.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['scratch_5fbuffer',['scratch_buffer',['../arm__nnexamples__cifar10_8cpp.html#a19548b1fad7cb85d95f5f276873a5de3',1,'scratch_buffer(): arm_nnexamples_cifar10.cpp'],['../arm__nnexamples__gru_8cpp.html#a935afa741bcc39e4c4c48b019d415d97',1,'scratch_buffer(): arm_nnexamples_gru.cpp']]], + ['sigmoidhtable_5fq15',['sigmoidHTable_q15',['../arm__nn__tables_8h.html#ab5096856d08f98c906b9b02e6c6a8bdf',1,'sigmoidHTable_q15(): arm_nn_tables.h'],['../arm__nntables_8c.html#a107a16eaa36f4392fa3ed3792ad6c2cb',1,'sigmoidHTable_q15(): arm_nntables.c']]], + ['sigmoidltable_5fq15',['sigmoidLTable_q15',['../arm__nn__tables_8h.html#add5ca535701805d3cb61287219975838',1,'sigmoidLTable_q15(): arm_nn_tables.h'],['../arm__nntables_8c.html#a69dc528cb377690d5b37accfdfd226b1',1,'sigmoidLTable_q15(): arm_nntables.c']]], + ['sigmoidtable_5fq15',['sigmoidTable_q15',['../arm__nn__tables_8h.html#ab4d7b07c387a3537d4efe21da86115b0',1,'sigmoidTable_q15(): arm_nntables.c'],['../arm__nntables_8c.html#ab4d7b07c387a3537d4efe21da86115b0',1,'sigmoidTable_q15(): arm_nntables.c']]], + ['sigmoidtable_5fq7',['sigmoidTable_q7',['../arm__nn__tables_8h.html#ae2ff3f4e7014f535358167150bdd544f',1,'sigmoidTable_q7(): arm_nntables.c'],['../arm__nntables_8c.html#ae2ff3f4e7014f535358167150bdd544f',1,'sigmoidTable_q7(): arm_nntables.c']]] +]; diff --git a/docs/NN/html/search/variables_8.html b/docs/NN/html/search/variables_8.html new file mode 100644 index 0000000..aa13bf2 --- /dev/null +++ b/docs/NN/html/search/variables_8.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_8.js b/docs/NN/html/search/variables_8.js new file mode 100644 index 0000000..1857c2e --- /dev/null +++ b/docs/NN/html/search/variables_8.js @@ -0,0 +1,10 @@ +var searchData= +[ + ['tanhhtable_5fq15',['tanhHTable_q15',['../arm__nntables_8c.html#a4d093f7b0dc798d4898ff4fd125b21a6',1,'arm_nntables.c']]], + ['tanhltable_5fq15',['tanhLTable_q15',['../arm__nntables_8c.html#a7cb5ad2fff7e241d09024332488a706e',1,'arm_nntables.c']]], + ['tanhtable_5fq15',['tanhTable_q15',['../arm__nn__tables_8h.html#a6faad2fec173b2702fd0f219a83ca320',1,'tanhTable_q15(): arm_nntables.c'],['../arm__nntables_8c.html#a6faad2fec173b2702fd0f219a83ca320',1,'tanhTable_q15(): arm_nntables.c']]], + ['tanhtable_5fq7',['tanhTable_q7',['../arm__nn__tables_8h.html#a4f854bdf13f630ec21b3ad074491e32f',1,'tanhTable_q7(): arm_nntables.c'],['../arm__nntables_8c.html#a4f854bdf13f630ec21b3ad074491e32f',1,'tanhTable_q7(): arm_nntables.c']]], + ['test_5fhistory',['test_history',['../arm__nnexamples__gru_8cpp.html#ac327d41d23812b53d83c2da91971cbfe',1,'arm_nnexamples_gru.cpp']]], + ['test_5finput1',['test_input1',['../arm__nnexamples__gru_8cpp.html#a8b0acc149c9bd4aadfb9c1fa8345f57a',1,'arm_nnexamples_gru.cpp']]], + ['test_5finput2',['test_input2',['../arm__nnexamples__gru_8cpp.html#aad5944359ea4a426550a87efd0d90b02',1,'arm_nnexamples_gru.cpp']]] +]; diff --git a/docs/NN/html/search/variables_9.html b/docs/NN/html/search/variables_9.html new file mode 100644 index 0000000..78cc249 --- /dev/null +++ b/docs/NN/html/search/variables_9.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_9.js b/docs/NN/html/search/variables_9.js new file mode 100644 index 0000000..6bb6ac4 --- /dev/null +++ b/docs/NN/html/search/variables_9.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['update_5fbias',['update_bias',['../namespacepara__gen.html#a3b9bab83acf3b4296f46165da08ddbc9',1,'para_gen']]], + ['update_5fgate_5fbias',['update_gate_bias',['../arm__nnexamples__gru_8cpp.html#ac5569d687768d693618f987a91e8aee5',1,'arm_nnexamples_gru.cpp']]], + ['update_5fgate_5fweights',['update_gate_weights',['../arm__nnexamples__gru_8cpp.html#aa2fc9b2b0449790ed7c37bab7fd3093e',1,'arm_nnexamples_gru.cpp']]], + ['update_5fweight',['update_weight',['../namespacepara__gen.html#ab8ce9efdee9cd118a25831839f9c5943',1,'para_gen']]] +]; diff --git a/docs/NN/html/search/variables_a.html b/docs/NN/html/search/variables_a.html new file mode 100644 index 0000000..592abaa --- /dev/null +++ b/docs/NN/html/search/variables_a.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_a.js b/docs/NN/html/search/variables_a.js new file mode 100644 index 0000000..0ea2ee4 --- /dev/null +++ b/docs/NN/html/search/variables_a.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['vec_5fdim',['vec_dim',['../namespacepara__gen.html#ad97bcbf0472c82d537ee41c0196e3b2a',1,'para_gen']]] +]; diff --git a/docs/NN/html/search/variables_b.html b/docs/NN/html/search/variables_b.html new file mode 100644 index 0000000..78052a1 --- /dev/null +++ b/docs/NN/html/search/variables_b.html @@ -0,0 +1,26 @@ + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/docs/NN/html/search/variables_b.js b/docs/NN/html/search/variables_b.js new file mode 100644 index 0000000..d84e951 --- /dev/null +++ b/docs/NN/html/search/variables_b.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['weight',['weight',['../namespacepara__gen.html#af3dbe004474bc66ad55591f470ff008c',1,'para_gen']]], + ['word',['word',['../unionarm__nnword.html#a35c7b2ae25e35e0ddcd9ec0a1a6f8d18',1,'arm_nnword']]] +]; diff --git a/docs/NN/html/sync_off.png b/docs/NN/html/sync_off.png new file mode 100644 index 0000000..3b443fc Binary files /dev/null and b/docs/NN/html/sync_off.png differ diff --git a/docs/NN/html/sync_on.png b/docs/NN/html/sync_on.png new file mode 100644 index 0000000..e08320f Binary files /dev/null and b/docs/NN/html/sync_on.png differ diff --git a/docs/NN/html/tab_a.png b/docs/NN/html/tab_a.png new file mode 100644 index 0000000..3b725c4 Binary files /dev/null and b/docs/NN/html/tab_a.png differ diff --git a/docs/NN/html/tab_b.png b/docs/NN/html/tab_b.png new file mode 100644 index 0000000..e2b4a86 Binary files /dev/null and b/docs/NN/html/tab_b.png differ diff --git a/docs/NN/html/tab_h.png b/docs/NN/html/tab_h.png new file mode 100644 index 0000000..fd5cb70 Binary files /dev/null and b/docs/NN/html/tab_h.png differ diff --git a/docs/NN/html/tab_s.png b/docs/NN/html/tab_s.png new file mode 100644 index 0000000..ab478c9 Binary files /dev/null and b/docs/NN/html/tab_s.png differ diff --git a/docs/NN/html/tab_topnav.png b/docs/NN/html/tab_topnav.png new file mode 100644 index 0000000..b257b77 Binary files /dev/null and b/docs/NN/html/tab_topnav.png differ diff --git a/docs/NN/html/tabs.css b/docs/NN/html/tabs.css new file mode 100644 index 0000000..ffbab50 --- /dev/null +++ b/docs/NN/html/tabs.css @@ -0,0 +1,71 @@ +.tabs, .tabs1, .tabs2, .tabs3 { + background-image: url('tab_b.png'); + width: 100%; + z-index: 101; + font-size: 10px; +} + +.tabs1 { + background-image: url('tab_topnav.png'); + font-size: 12px; +} + +.tabs2 { + font-size: 10px; +} +.tabs3 { + font-size: 9px; +} + +.tablist { + margin: 0; + padding: 0; + display: table; + line-height: 24px; +} + +.tablist li { + float: left; + display: table-cell; + background-image: url('tab_b.png'); + list-style: none; +} + +.tabs1 .tablist li { + float: left; + display: table-cell; + background-image: url('tab_topnav.png'); + list-style: none; +} + +.tablist a { + display: block; + padding: 0 20px; + font-weight: bold; + background-image:url('tab_s.png'); + background-repeat:no-repeat; + background-position:right; + color: #283A5D; + text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9); + text-decoration: none; + outline: none; +} + +.tabs3 .tablist a { + padding: 0 10px; +} + +.tablist a:hover { + background-image: url('tab_h.png'); + background-repeat:repeat-x; + color: #fff; + text-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); + text-decoration: none; +} + +.tablist li.current a { + background-image: url('tab_a.png'); + background-repeat:repeat-x; + color: #fff; + text-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); +} diff --git a/docs/NN/html/unionarm__nnword.html b/docs/NN/html/unionarm__nnword.html new file mode 100644 index 0000000..ec54dee --- /dev/null +++ b/docs/NN/html/unionarm__nnword.html @@ -0,0 +1,196 @@ + + + + + +arm_nnword Union Reference +CMSIS-NN: arm_nnword Union Reference + + + + + + + + + + + + + + +
    +
    + + + + + + + +
    +
    CMSIS-NN +  Version 1.1.0 +
    +
    CMSIS NN Software Library
    +
    +
    + +
    +
      + +
    +
    + + + + +
    +
    + +
    +
    +
    + +
    + + + + +
    + +
    + +
    + +
    +
    arm_nnword Union Reference
    +
    +
    + +

    Union for SIMD access of Q31/Q15/Q7 types. +

    + + + + + + + + +

    +Data Fields

    q31_t word
     
    q15_t half_words [2]
     
    q7_t bytes [4]
     
    +

    Field Documentation

    + +
    +
    + + + + +
    q7_t arm_nnword::bytes[4]
    +
    +
    + +
    +
    + + + + +
    q15_t arm_nnword::half_words[2]
    +
    +

    Q15 type

    + +

    Referenced by arm_convolve_HWC_q7_RGB().

    + +
    +
    + +
    +
    + + + + +
    q31_t arm_nnword::word
    +
    +
    +
    +
    + + + + diff --git a/docs/NN/html/unionarm__nnword.js b/docs/NN/html/unionarm__nnword.js new file mode 100644 index 0000000..950bd7e --- /dev/null +++ b/docs/NN/html/unionarm__nnword.js @@ -0,0 +1,6 @@ +var unionarm__nnword = +[ + [ "bytes", "unionarm__nnword.html#ac7cff6480a8e29d95f29b73cb1267249", null ], + [ "half_words", "unionarm__nnword.html#a9b5e49e4e2c4b7203e07b305386bb2ba", null ], + [ "word", "unionarm__nnword.html#a35c7b2ae25e35e0ddcd9ec0a1a6f8d18", null ] +]; \ No newline at end of file -- cgit