ziko 0.0.14 → 0.0.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) hide show
  1. package/dist/ziko.cjs +13435 -11825
  2. package/dist/ziko.js +13958 -12406
  3. package/dist/ziko.min.js +2 -2
  4. package/dist/ziko.mjs +13401 -11859
  5. package/package.json +2 -1
  6. package/src/__helpers__/index.js +61 -41
  7. package/src/app/index.js +21 -12
  8. package/src/app/json-style-sheet.js +64 -0
  9. package/src/app/params.js +40 -0
  10. package/src/app/routes.js +58 -0
  11. package/src/app/spa-file-based-routing.js +74 -0
  12. package/src/app/spa.js +55 -0
  13. package/src/app/ziko-app.js +39 -0
  14. package/src/data/api/fetchdom.js +13 -13
  15. package/src/data/api/index.js +3 -3
  16. package/src/data/api/preload.js +10 -10
  17. package/src/data/converter/adoc.js +130 -130
  18. package/src/data/converter/array.js +42 -42
  19. package/src/data/converter/canvas.js +24 -24
  20. package/src/data/converter/css.js +37 -0
  21. package/src/data/converter/csv.js +32 -32
  22. package/src/data/converter/idea.txt +9 -9
  23. package/src/data/converter/index.js +37 -34
  24. package/src/data/converter/json.js +80 -80
  25. package/src/data/converter/markdown.js +95 -95
  26. package/src/data/converter/object.js +69 -69
  27. package/src/data/converter/svg.js +10 -10
  28. package/src/data/index.js +16 -73
  29. package/src/data/parser/index.js +1 -0
  30. package/src/data/parser/xml.js +46 -46
  31. package/src/data/string/patterns.js +11 -11
  32. package/src/data/string/string.js +169 -169
  33. package/src/{app/app.js → global/app/index.js} +45 -45
  34. package/src/{app → global}/component/index.js +38 -38
  35. package/src/global/globals/index.js +20 -0
  36. package/src/global/index.js +12 -0
  37. package/src/{app → global}/params/index.js +39 -39
  38. package/src/{app → global}/router/index.js +66 -66
  39. package/src/{app → global}/seo/index.js +42 -42
  40. package/src/global/style/index.js +1 -0
  41. package/src/{app → global}/themes/dark.js +884 -884
  42. package/src/{app → global}/themes/index.js +10 -10
  43. package/src/{app → global}/themes/light.js +254 -254
  44. package/src/graphics/canvas/canvas.js +188 -188
  45. package/src/graphics/canvas/elements/Basic/arc.js +42 -42
  46. package/src/graphics/canvas/elements/Basic/line.js +25 -25
  47. package/src/graphics/canvas/elements/Basic/points.js +47 -47
  48. package/src/graphics/canvas/elements/Basic/polygon.js +6 -6
  49. package/src/graphics/canvas/elements/Basic/rect.js +45 -45
  50. package/src/graphics/canvas/elements/Chart/scatter.js +2 -2
  51. package/src/graphics/canvas/elements/Element.js +114 -114
  52. package/src/graphics/canvas/elements/index.js +12 -12
  53. package/src/graphics/canvas/index.js +14 -14
  54. package/src/graphics/canvas/utils/color.js +7 -7
  55. package/src/graphics/canvas/utils/floodFill.js +57 -57
  56. package/src/graphics/index.js +68 -68
  57. package/src/graphics/svg/Elements/Basic/circle.js +25 -25
  58. package/src/graphics/svg/Elements/Basic/ellipse.js +20 -20
  59. package/src/graphics/svg/Elements/Basic/foreignObject.js +32 -32
  60. package/src/graphics/svg/Elements/Basic/groupe.js +29 -29
  61. package/src/graphics/svg/Elements/Basic/image.js +32 -32
  62. package/src/graphics/svg/Elements/Basic/line.js +28 -28
  63. package/src/graphics/svg/Elements/Basic/link.js +30 -30
  64. package/src/graphics/svg/Elements/Basic/path.js +58 -58
  65. package/src/graphics/svg/Elements/Basic/polygon.js +31 -31
  66. package/src/graphics/svg/Elements/Basic/polyline.js +3 -3
  67. package/src/graphics/svg/Elements/Basic/rect.js +42 -42
  68. package/src/graphics/svg/Elements/Basic/text.js +25 -25
  69. package/src/graphics/svg/Elements/Derived/grid.js +8 -8
  70. package/src/graphics/svg/Elements/ZikoSvgElement.js +46 -46
  71. package/src/graphics/svg/Elements/index.js +14 -14
  72. package/src/graphics/svg/index.js +1 -1
  73. package/src/graphics/svg/svg.js +114 -114
  74. package/src/index.js +84 -88
  75. package/src/math/calculus/derivation/index.js +7 -0
  76. package/src/math/calculus/index.js +2 -1
  77. package/src/math/calculus/special-functions/bessel.js +30 -30
  78. package/src/math/calculus/special-functions/beta.js +37 -37
  79. package/src/math/calculus/special-functions/gamma.js +29 -29
  80. package/src/math/calculus/special-functions/index.js +4 -4
  81. package/src/math/complex/index.js +202 -202
  82. package/src/math/const.js +2 -2
  83. package/src/math/discret/Combinaison/index.js +33 -33
  84. package/src/math/discret/Conversion/index.js +85 -85
  85. package/src/math/discret/Logic/index.js +45 -45
  86. package/src/math/discret/Permutation/index.js +30 -30
  87. package/src/math/discret/Set/index.js +1 -1
  88. package/src/math/discret/Set/power-set.js +14 -14
  89. package/src/math/discret/Set/sub-set.js +10 -10
  90. package/src/math/discret/index.js +12 -23
  91. package/src/math/functions/helper.js +20 -0
  92. package/src/math/functions/index.js +161 -181
  93. package/src/math/index.js +32 -189
  94. package/src/math/matrix/Decomposition.js +90 -90
  95. package/src/math/matrix/LinearSystem.js +9 -9
  96. package/src/math/matrix/Matrix.js +716 -716
  97. package/src/math/matrix/index.js +2 -2
  98. package/src/math/random/index.js +172 -172
  99. package/src/math/signal/__np.py.txt +39 -39
  100. package/src/math/signal/conv.js +174 -174
  101. package/src/math/signal/fft.js +54 -54
  102. package/src/math/signal/filter.js +38 -38
  103. package/src/math/signal/functions.js +145 -145
  104. package/src/math/signal/index.js +109 -109
  105. package/src/math/statistics/Functions/index.js +99 -99
  106. package/src/math/statistics/index.js +15 -15
  107. package/src/math/utils/arithmetic.js +138 -138
  108. package/src/math/utils/checkers.js +29 -29
  109. package/src/math/utils/conversions.js +19 -19
  110. package/src/math/utils/discret.js +51 -51
  111. package/src/math/utils/index.js +101 -101
  112. package/src/math/utils/mapfun.js +49 -49
  113. package/src/reactivity/events/{Partiel/Input.js → Input.js} +62 -59
  114. package/src/reactivity/events/{Global/Pointer.js → Pointer.js} +232 -234
  115. package/src/reactivity/events/ZikoEvent.js +90 -90
  116. package/src/reactivity/events/{Global/Click.js → click.js} +60 -56
  117. package/src/reactivity/events/{Global/Clipboard.js → clipboard.js} +88 -84
  118. package/src/reactivity/events/{Global/CustomEvent.js → custom-event.js} +57 -53
  119. package/src/reactivity/events/{Global/Drag.js → drag.js} +136 -136
  120. package/src/reactivity/events/{Global/Focus.js → focus.js} +59 -56
  121. package/src/reactivity/events/{Partiel/Hash.js → hash.js} +47 -44
  122. package/src/reactivity/events/index.js +62 -62
  123. package/src/reactivity/events/{Global/Key.js → key.js} +102 -104
  124. package/src/reactivity/events/{Global/Mouse.js → mouse.js} +233 -230
  125. package/src/reactivity/events/{Global/Swipe.js → swipe.js} +149 -147
  126. package/src/reactivity/events/{Global/Wheel.js → wheel.js} +47 -44
  127. package/src/reactivity/hooks/{Contexte → contexte}/useSuccesifKeys.js +13 -13
  128. package/src/reactivity/hooks/{Decorators → decorators}/index.js +6 -6
  129. package/src/reactivity/hooks/{Decorators → decorators}/time.js +16 -16
  130. package/src/reactivity/hooks/{Decorators → decorators}/type.js +87 -87
  131. package/src/reactivity/hooks/head/index.js +5 -0
  132. package/src/reactivity/hooks/{UI → head}/useCssText.js +21 -21
  133. package/src/reactivity/hooks/{UI → head}/useFavIcon.js +37 -37
  134. package/src/reactivity/hooks/head/useHead.js +28 -0
  135. package/src/reactivity/hooks/head/useMeta.js +52 -0
  136. package/src/reactivity/hooks/{UI → head}/useTitle.js +29 -29
  137. package/src/reactivity/hooks/index.js +91 -85
  138. package/src/reactivity/hooks/{Interactions → interactions}/index.js +3 -3
  139. package/src/reactivity/hooks/{Interactions → interactions}/useBluetooth.js +47 -47
  140. package/src/reactivity/hooks/{Interactions → interactions}/useChannel.js +49 -49
  141. package/src/reactivity/hooks/{Interactions → interactions}/useEventEmmiter.js +63 -63
  142. package/src/reactivity/hooks/{Interactions → interactions}/useThread.js +43 -43
  143. package/src/reactivity/hooks/sensors/index.js +2 -0
  144. package/src/reactivity/hooks/{Sensors → sensors}/useBattery.js +35 -35
  145. package/src/reactivity/hooks/{Sensors → sensors}/useGeolocation.js +16 -16
  146. package/src/reactivity/hooks/{Storage → storage}/useStorage.js +72 -72
  147. package/src/reactivity/hooks/todo.md +26 -26
  148. package/src/reactivity/hooks/ui/index.js +5 -0
  149. package/src/reactivity/hooks/{UI → ui}/useMediaQuery.js +43 -43
  150. package/src/reactivity/hooks/{UI → ui}/useStyle.js +79 -79
  151. package/src/reactivity/hooks/{UI → ui}/useTheme.js +61 -61
  152. package/src/reactivity/idea +1 -1
  153. package/src/reactivity/index.js +11 -21
  154. package/src/reactivity/observer/attributes.js +28 -28
  155. package/src/reactivity/observer/children.js +36 -36
  156. package/src/reactivity/observer/index.js +6 -44
  157. package/src/reactivity/observer/intersection.js +43 -43
  158. package/src/reactivity/observer/mutation.js +112 -112
  159. package/src/reactivity/observer/resize.js +46 -46
  160. package/src/reactivity/observer/screen.js +44 -44
  161. package/src/reactivity/observer/screen.js.txt +83 -83
  162. package/src/reactivity/observer/screen.txt +12 -12
  163. package/src/time/animation.js +75 -75
  164. package/src/time/index.js +12 -54
  165. package/src/time/loop.js +87 -87
  166. package/src/time/utils/decorators.js +16 -16
  167. package/src/time/utils/ease.js +143 -143
  168. package/src/time/utils/index.js +17 -17
  169. package/src/time/utils/performance.js +15 -15
  170. package/src/time/utils/ui.js +25 -25
  171. package/src/types.js +73 -71
  172. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/accordion/accordion.js +42 -45
  173. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/accordion/collapsible.js +82 -82
  174. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/accordion/index.js +1 -1
  175. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/alert/alert.js +80 -80
  176. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/alert/palette.js +51 -51
  177. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/carousel/index.js +50 -50
  178. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/SubElements.js.txt +104 -104
  179. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/code-cell.js +194 -194
  180. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/code-note.js +71 -71
  181. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/index.js +1 -1
  182. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/code-note/sub-elements.js +66 -66
  183. package/src/{user-interface → ui}/elements/derived/elements/Swipper.js +3 -3
  184. package/src/{user-interface → ui}/elements/derived/elements/index.js +9 -9
  185. package/src/{user-interface/elements/derived/Flex.js → ui/elements/derived/flex/index.js} +102 -102
  186. package/src/{user-interface/elements/derived/Grid.js → ui/elements/derived/grid/index.js} +32 -32
  187. package/src/ui/elements/derived/index.js +12 -0
  188. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/menu/menu3d.js +259 -259
  189. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/modal/index.js +91 -91
  190. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/pagination/breadcrumbs.js +53 -53
  191. package/src/ui/elements/derived/slider/__ZikoUISlider__.js +112 -0
  192. package/src/ui/elements/derived/slider/hSlider.js +34 -0
  193. package/src/ui/elements/derived/slider/index.js +12 -0
  194. package/src/ui/elements/derived/slider/vSlider.js +27 -0
  195. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/splitter/__ZikoUISplitter__.js +61 -61
  196. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/splitter/hsplitter.js +39 -39
  197. package/src/ui/elements/derived/splitter/index.js +12 -0
  198. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/splitter/vsplitter.js +39 -39
  199. package/src/{user-interface/elements/derived/elements → ui/elements/derived}/tabs/index.js +179 -179
  200. package/src/{user-interface → ui}/elements/primitives/ZikoUIContainerElement.js +126 -126
  201. package/src/{user-interface → ui}/elements/primitives/ZikoUIElement.js +492 -480
  202. package/src/{user-interface → ui}/elements/primitives/embaded/html.js +19 -20
  203. package/src/{user-interface → ui}/elements/primitives/embaded/index.js +3 -3
  204. package/src/{user-interface → ui}/elements/primitives/embaded/pdf.js +16 -17
  205. package/src/{user-interface → ui}/elements/primitives/embaded/youtube.js +23 -25
  206. package/src/{user-interface → ui}/elements/primitives/index.js +7 -7
  207. package/src/{user-interface → ui}/elements/primitives/io/Form/index.js +41 -41
  208. package/src/{user-interface → ui}/elements/primitives/io/Form/index.js.txt +104 -104
  209. package/src/{user-interface → ui}/elements/primitives/io/Inputs/__helpers__.js +51 -51
  210. package/src/{user-interface → ui}/elements/primitives/io/Inputs/index.js +12 -12
  211. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input/index.js +98 -98
  212. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-camera/index.js +26 -26
  213. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-checkbox/index.js +25 -25
  214. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-color/index.js +15 -15
  215. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-date-time/index.js +2 -2
  216. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-date-time/input-date-time.js +13 -13
  217. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-date-time/input-date.js +13 -13
  218. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-date-time/input-time.js +13 -13
  219. package/src/ui/elements/primitives/io/Inputs/input-email-password/index.js +2 -0
  220. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-email-password/input-email.js +14 -14
  221. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-email-password/input-password.js +13 -13
  222. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-file/input-image.js +42 -42
  223. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-number/index.js +36 -36
  224. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-radio/index.js +25 -25
  225. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-search/index.js +45 -45
  226. package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-slider/index.js +34 -34
  227. package/src/{user-interface → ui}/elements/primitives/io/Select/index.js +19 -19
  228. package/src/{user-interface → ui}/elements/primitives/io/Textarea/index.js +17 -17
  229. package/src/{user-interface → ui}/elements/primitives/io/index.js +3 -3
  230. package/src/{user-interface → ui}/elements/primitives/list/index.js +138 -138
  231. package/src/{user-interface → ui}/elements/primitives/media/Audio/index.js +16 -16
  232. package/src/{user-interface → ui}/elements/primitives/media/Image/figure.js +18 -18
  233. package/src/{user-interface → ui}/elements/primitives/media/Image/image.js +36 -36
  234. package/src/ui/elements/primitives/media/Image/index.js +2 -0
  235. package/src/{user-interface → ui}/elements/primitives/media/Video/index.js +26 -26
  236. package/src/{user-interface → ui}/elements/primitives/media/__ZikoUIDynamicMediaELement__.js +46 -46
  237. package/src/{user-interface → ui}/elements/primitives/media/index.js +2 -2
  238. package/src/{user-interface → ui}/elements/primitives/misc/index.js +101 -100
  239. package/src/ui/elements/primitives/misc/xml-wrapper.js +37 -0
  240. package/src/{user-interface → ui}/elements/primitives/semantic/index.js +81 -81
  241. package/src/{user-interface → ui}/elements/primitives/table/elements.js +93 -93
  242. package/src/ui/elements/primitives/table/index.js +3 -0
  243. package/src/{user-interface → ui}/elements/primitives/table/table.js +115 -115
  244. package/src/{user-interface → ui}/elements/primitives/table/utils.js +11 -11
  245. package/src/{user-interface → ui}/elements/primitives/text/__ZikoUIText__.js +71 -71
  246. package/src/{user-interface → ui}/elements/primitives/text/heading.js +35 -35
  247. package/src/{user-interface → ui}/elements/primitives/text/index.js +2 -2
  248. package/src/{user-interface → ui}/elements/primitives/text/p.js +26 -26
  249. package/src/{user-interface → ui}/elements/primitives/text/text.js +80 -80
  250. package/src/ui/index.js +29 -0
  251. package/src/{user-interface → ui}/style/index.js +515 -509
  252. package/src/{user-interface → ui}/utils/index.js +69 -69
  253. package/src/reactivity/events/Global/Touch.js +0 -0
  254. package/src/reactivity/hooks/Sensors/index.js +0 -2
  255. package/src/reactivity/hooks/UI/index.js +0 -5
  256. package/src/user-interface/elements/derived/elements/splitter/index.js +0 -2
  257. package/src/user-interface/elements/derived/index.js +0 -3
  258. package/src/user-interface/elements/primitives/io/Inputs/input-email-password/index.js +0 -2
  259. package/src/user-interface/elements/primitives/media/Image/index.js +0 -2
  260. package/src/user-interface/elements/primitives/table/index.js +0 -3
  261. package/src/user-interface/index.js +0 -190
  262. /package/src/app/{globals/index.js → globals.js} +0 -0
  263. /package/src/reactivity/events/{Partiel/Media.js → media.js} +0 -0
  264. /package/src/{app/accessibility/index.js → reactivity/events/touch.js} +0 -0
  265. /package/src/reactivity/hooks/{Contexte → contexte}/index.js +0 -0
  266. /package/src/reactivity/hooks/{Interactions → interactions}/useSerial.js +0 -0
  267. /package/src/reactivity/hooks/{Interactions → interactions}/useUsb.js +0 -0
  268. /package/src/reactivity/hooks/{Sensors → sensors}/useCamera.js +0 -0
  269. /package/src/reactivity/hooks/{Sensors → sensors}/useMicro.js +0 -0
  270. /package/src/reactivity/hooks/{Sensors → sensors}/useOrientation.js +0 -0
  271. /package/src/reactivity/hooks/{Storage → storage}/index.js +0 -0
  272. /package/src/reactivity/hooks/{Storage → storage}/useCookie.js +0 -0
  273. /package/src/reactivity/hooks/{Storage → storage}/useIndexedDb.js +0 -0
  274. /package/src/reactivity/hooks/{UI → ui}/useCssLink.js +0 -0
  275. /package/src/reactivity/hooks/{UI → ui}/useLinearGradient.js +0 -0
  276. /package/src/reactivity/hooks/{UI → ui}/useRadialGradient.js +0 -0
  277. /package/src/{user-interface/elements/derived/elements → ui/elements/derived}/alert/index.js +0 -0
  278. /package/src/{user-interface → ui}/elements/derived/elements/Notification.js +0 -0
  279. /package/src/{user-interface → ui}/elements/derived/elements/Popover.js +0 -0
  280. /package/src/{user-interface → ui}/elements/derived/elements/Popup.js +0 -0
  281. /package/src/{user-interface → ui}/elements/derived/elements/Timeline.js +0 -0
  282. /package/src/{user-interface → ui}/elements/derived/elements/Toast.js +0 -0
  283. /package/src/{user-interface → ui}/elements/derived/elements/Treeview.js +0 -0
  284. /package/src/{user-interface → ui}/elements/derived/elements/columns.js +0 -0
  285. /package/src/{user-interface → ui}/elements/derived/elements/fab.js +0 -0
  286. /package/src/{user-interface/elements/derived/elements → ui/elements/derived}/menu/index.js +0 -0
  287. /package/src/{user-interface/elements/derived/elements → ui/elements/derived}/pagination/index.js +0 -0
  288. /package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-file/index.js +0 -0
  289. /package/src/{user-interface → ui}/elements/primitives/io/Inputs/input-file/input-file.js +0 -0
  290. /package/src/{user-interface → ui}/elements/primitives/list/elements.js +0 -0
  291. /package/src/{user-interface → ui}/elements/primitives/text/pre.js +0 -0
@@ -1,175 +1,175 @@
1
- import { Matrix , matrix } from "../matrix/index.js";
2
- import { sqrt } from "../functions/index.js";
3
- const conv1d=(input, kernel , circular = true)=>{
4
- const INPUT_LENGTH = input.length;
5
- const KERNEL_LENGTH = kernel.length;
6
- const output = [];
7
- const LENGTH_OUT = circular ? Math.max(INPUT_LENGTH,KERNEL_LENGTH) : INPUT_LENGTH + KERNEL_LENGTH - 1;
8
- for (let i = 0; i < LENGTH_OUT; i++) {
9
- let sum = 0;
10
- for (let j = 0; j < KERNEL_LENGTH; j++) {
11
- const inputIndex = i + j - Math.floor(KERNEL_LENGTH / 2);
12
- // Apply zero-padding for out-of-bounds indices
13
- const inputValue = inputIndex >= 0 && inputIndex < INPUT_LENGTH
14
- ? input[inputIndex]
15
- : 0;
16
- sum += inputValue * kernel[j];
17
- }
18
- output.push(sum);
19
- }
20
- return output;
21
- }
22
-
23
- const conv2d = (input, kernel, circular = true) => {
24
- if(!(input instanceof Matrix)) input = matrix(input);
25
- if(!(kernel instanceof Matrix)) kernel = matrix(kernel);
26
- const INPUT_ROWS=input.rows;
27
- const INPUT_COLS=input.cols;
28
- const OUTPUT_ROWS = circular ? Math.max(input.rows,kernel.rows) : input.rows + kernel.rows-1;
29
- const OUTPUT_COLS = circular ? Math.max(input.cols,kernel.cols) : input.cols + kernel.cols-1;
30
- const KERNEL_SIZE = kernel.rows;
31
- const output = [];
32
- for (let i = 0; i < OUTPUT_ROWS ; i++) {
33
- const row = [];
34
- for (let j = 0; j < OUTPUT_COLS ; j++) {
35
- let sum = 0;
36
- for (let k = 0; k < KERNEL_SIZE; k++) {
37
- for (let l = 0; l < KERNEL_SIZE; l++) {
38
- const rowIndex = i + k - Math.floor(KERNEL_SIZE / 2);
39
- const colIndex = j + l - Math.floor(KERNEL_SIZE / 2);
40
- // Apply zero-padding for out-of-bounds indices
41
- const inputValue = (rowIndex >= 0 && rowIndex < INPUT_ROWS &&
42
- colIndex >= 0 && colIndex < INPUT_COLS)
43
- ? input[rowIndex][colIndex]
44
- : 0;
45
- sum += inputValue * kernel[k][l];
46
- }
47
- }
48
- row.push(sum);
49
- }
50
- output.push(row);
51
- }
52
- return output;
53
- };
54
-
55
- var convolute=(parent,kernel = [0, -1, 0, -1, 5, -1, 0, -1, 0], x1 = 0, y1 = 0, x2 = parent.element.width, y2 = parent.element.height)=>{
56
- if(kernel instanceof Matrix)kernel=kernel.arr.flat(1)
57
- var opaque = 1;
58
- var pixels = parent.ctx.getImageData(x1, y1, x2, y2);
59
- var side = Math.round(sqrt(kernel.length));
60
- var halfSide = Math.floor(side / 2);
61
- var src = pixels.data;
62
- var sw = pixels.width;
63
- var sh = pixels.height;
64
- // pad output by the convolution matrix
65
- var w = sw;
66
- var h = sh;
67
- var output = parent.ctx.createImageData(w, h);
68
- var dst = output.data;
69
- // go through the destination image pixels
70
- var alphaFac = opaque ? 1 : 0;
71
- for (var y = 0; y < h; y++) {
72
- for (var x = 0; x < w; x++) {
73
- var sy = y;
74
- var sx = x;
75
- var dstOff = (y * w + x) * 4;
76
- // calculate the weighed sum of the source image pixels that
77
- // fall under the convolution matrix
78
- var r = 0,
79
- g = 0,
80
- b = 0,
81
- a = 0;
82
- for (var cy = 0; cy < side; cy++) {
83
- for (var cx = 0; cx < side; cx++) {
84
- var scy = sy + cy - halfSide;
85
- var scx = sx + cx - halfSide;
86
- if (scy >= 0 && scy < sh && scx >= 0 && scx < sw) {
87
- var srcOff = (scy * sw + scx) * 4;
88
- var wt = kernel[cy * side + cx];
89
- r += src[srcOff] * wt;
90
- g += src[srcOff + 1] * wt;
91
- b += src[srcOff + 2] * wt;
92
- a += src[srcOff + 3] * wt;
93
- }
94
- }
95
- }
96
- dst[dstOff] = r;
97
- dst[dstOff + 1] = g;
98
- dst[dstOff + 2] = b;
99
- dst[dstOff + 3] = a + alphaFac * (255 - a);
100
- }
101
- }
102
- return output;
103
- }
104
-
105
- convolute=(parent,kernel = [0, -1, 0, -1, 5, -1, 0, -1, 0], x1 = 0, y1 = 0, x2 = parent.element.width, y2 = parent.element.height)=>{
106
- if(kernel instanceof Matrix)kernel=kernel.arr.flat(1)
107
- var opaque = 1;
108
- var pixels = parent.ctx.getImageData(x1, y1, x2, y2);
109
- var side = Math.round(sqrt(kernel.length));
110
- var halfSide = Math.floor(side / 2);
111
- var src = pixels.data;
112
- var sw = pixels.width;
113
- var sh = pixels.height;
114
- // pad output by the convolution matrix
115
- var w = sw;
116
- var h = sh;
117
- var output = parent.ctx.createImageData(w, h);
118
- var dst = output.data;
119
- // go through the destination image pixels
120
- var alphaFac = opaque ? 1 : 0;
121
- for (var y = 0; y < h; y++) {
122
- for (var x = 0; x < w; x++) {
123
- var sy = y;
124
- var sx = x;
125
- var dstOff = (y * w + x) * 4;
126
- // calculate the weighed sum of the source image pixels that
127
- // fall under the convolution matrix
128
- var r = 0,
129
- g = 0,
130
- b = 0,
131
- a = 0;
132
- for (var cy = 0; cy < side; cy++) {
133
- for (var cx = 0; cx < side; cx++) {
134
- var scy = sy + cy - halfSide;
135
- var scx = sx + cx - halfSide;
136
- if (scy >= 0 && scy < sh && scx >= 0 && scx < sw) {
137
- var srcOff = (scy * sw + scx) * 4;
138
- var wt = kernel[cy * side + cx];
139
- r += src[srcOff] * wt;
140
- g += src[srcOff + 1] * wt;
141
- b += src[srcOff + 2] * wt;
142
- a += src[srcOff + 3] * wt;
143
- }
144
- }
145
- }
146
- dst[dstOff] = r;
147
- dst[dstOff + 1] = g;
148
- dst[dstOff + 2] = b;
149
- dst[dstOff + 3] = a + alphaFac * (255 - a);
150
- }
151
- }
152
- return output;
153
- }
154
- const conv=(input,kernel,circular)=>{
155
- if(input instanceof Matrix || (input instanceof Array && input[0][0]))return conv2d(input,kernel,circular);
156
- return conv1d(input,kernel,circular)
157
- }
158
- const circularConv=(input,kernel)=>conv(input,kernel,true);
159
- const linearConv=(input,kernel)=>conv(input,kernel,false);
160
- const circularConv1d=(input,kernel)=>conv1d(input,kernel,true);
161
- const circularConv2d=(input,kernel)=>conv2d(input,kernel,true);
162
- const linearConv1d=(input,kernel)=>conv1d(input,kernel,false);
163
- const linearConv2d=(input,kernel)=>conv2d(input,kernel,false);
164
- export{
165
- conv1d,
166
- conv2d,
167
- conv,
168
- circularConv,
169
- linearConv,
170
- circularConv1d,
171
- linearConv1d,
172
- circularConv2d,
173
- linearConv2d,
174
- convolute
1
+ import { Matrix , matrix } from "../matrix/index.js";
2
+ import { sqrt } from "../functions/index.js";
3
+ const conv1d=(input, kernel , circular = true)=>{
4
+ const INPUT_LENGTH = input.length;
5
+ const KERNEL_LENGTH = kernel.length;
6
+ const output = [];
7
+ const LENGTH_OUT = circular ? Math.max(INPUT_LENGTH,KERNEL_LENGTH) : INPUT_LENGTH + KERNEL_LENGTH - 1;
8
+ for (let i = 0; i < LENGTH_OUT; i++) {
9
+ let sum = 0;
10
+ for (let j = 0; j < KERNEL_LENGTH; j++) {
11
+ const inputIndex = i + j - Math.floor(KERNEL_LENGTH / 2);
12
+ // Apply zero-padding for out-of-bounds indices
13
+ const inputValue = inputIndex >= 0 && inputIndex < INPUT_LENGTH
14
+ ? input[inputIndex]
15
+ : 0;
16
+ sum += inputValue * kernel[j];
17
+ }
18
+ output.push(sum);
19
+ }
20
+ return output;
21
+ }
22
+
23
+ const conv2d = (input, kernel, circular = true) => {
24
+ if(!(input instanceof Matrix)) input = matrix(input);
25
+ if(!(kernel instanceof Matrix)) kernel = matrix(kernel);
26
+ const INPUT_ROWS=input.rows;
27
+ const INPUT_COLS=input.cols;
28
+ const OUTPUT_ROWS = circular ? Math.max(input.rows,kernel.rows) : input.rows + kernel.rows-1;
29
+ const OUTPUT_COLS = circular ? Math.max(input.cols,kernel.cols) : input.cols + kernel.cols-1;
30
+ const KERNEL_SIZE = kernel.rows;
31
+ const output = [];
32
+ for (let i = 0; i < OUTPUT_ROWS ; i++) {
33
+ const row = [];
34
+ for (let j = 0; j < OUTPUT_COLS ; j++) {
35
+ let sum = 0;
36
+ for (let k = 0; k < KERNEL_SIZE; k++) {
37
+ for (let l = 0; l < KERNEL_SIZE; l++) {
38
+ const rowIndex = i + k - Math.floor(KERNEL_SIZE / 2);
39
+ const colIndex = j + l - Math.floor(KERNEL_SIZE / 2);
40
+ // Apply zero-padding for out-of-bounds indices
41
+ const inputValue = (rowIndex >= 0 && rowIndex < INPUT_ROWS &&
42
+ colIndex >= 0 && colIndex < INPUT_COLS)
43
+ ? input[rowIndex][colIndex]
44
+ : 0;
45
+ sum += inputValue * kernel[k][l];
46
+ }
47
+ }
48
+ row.push(sum);
49
+ }
50
+ output.push(row);
51
+ }
52
+ return output;
53
+ };
54
+
55
+ var convolute=(parent,kernel = [0, -1, 0, -1, 5, -1, 0, -1, 0], x1 = 0, y1 = 0, x2 = parent.element.width, y2 = parent.element.height)=>{
56
+ if(kernel instanceof Matrix)kernel=kernel.arr.flat(1)
57
+ var opaque = 1;
58
+ var pixels = parent.ctx.getImageData(x1, y1, x2, y2);
59
+ var side = Math.round(sqrt(kernel.length));
60
+ var halfSide = Math.floor(side / 2);
61
+ var src = pixels.data;
62
+ var sw = pixels.width;
63
+ var sh = pixels.height;
64
+ // pad output by the convolution matrix
65
+ var w = sw;
66
+ var h = sh;
67
+ var output = parent.ctx.createImageData(w, h);
68
+ var dst = output.data;
69
+ // go through the destination image pixels
70
+ var alphaFac = opaque ? 1 : 0;
71
+ for (var y = 0; y < h; y++) {
72
+ for (var x = 0; x < w; x++) {
73
+ var sy = y;
74
+ var sx = x;
75
+ var dstOff = (y * w + x) * 4;
76
+ // calculate the weighed sum of the source image pixels that
77
+ // fall under the convolution matrix
78
+ var r = 0,
79
+ g = 0,
80
+ b = 0,
81
+ a = 0;
82
+ for (var cy = 0; cy < side; cy++) {
83
+ for (var cx = 0; cx < side; cx++) {
84
+ var scy = sy + cy - halfSide;
85
+ var scx = sx + cx - halfSide;
86
+ if (scy >= 0 && scy < sh && scx >= 0 && scx < sw) {
87
+ var srcOff = (scy * sw + scx) * 4;
88
+ var wt = kernel[cy * side + cx];
89
+ r += src[srcOff] * wt;
90
+ g += src[srcOff + 1] * wt;
91
+ b += src[srcOff + 2] * wt;
92
+ a += src[srcOff + 3] * wt;
93
+ }
94
+ }
95
+ }
96
+ dst[dstOff] = r;
97
+ dst[dstOff + 1] = g;
98
+ dst[dstOff + 2] = b;
99
+ dst[dstOff + 3] = a + alphaFac * (255 - a);
100
+ }
101
+ }
102
+ return output;
103
+ }
104
+
105
+ convolute=(parent,kernel = [0, -1, 0, -1, 5, -1, 0, -1, 0], x1 = 0, y1 = 0, x2 = parent.element.width, y2 = parent.element.height)=>{
106
+ if(kernel instanceof Matrix)kernel=kernel.arr.flat(1)
107
+ var opaque = 1;
108
+ var pixels = parent.ctx.getImageData(x1, y1, x2, y2);
109
+ var side = Math.round(sqrt(kernel.length));
110
+ var halfSide = Math.floor(side / 2);
111
+ var src = pixels.data;
112
+ var sw = pixels.width;
113
+ var sh = pixels.height;
114
+ // pad output by the convolution matrix
115
+ var w = sw;
116
+ var h = sh;
117
+ var output = parent.ctx.createImageData(w, h);
118
+ var dst = output.data;
119
+ // go through the destination image pixels
120
+ var alphaFac = opaque ? 1 : 0;
121
+ for (var y = 0; y < h; y++) {
122
+ for (var x = 0; x < w; x++) {
123
+ var sy = y;
124
+ var sx = x;
125
+ var dstOff = (y * w + x) * 4;
126
+ // calculate the weighed sum of the source image pixels that
127
+ // fall under the convolution matrix
128
+ var r = 0,
129
+ g = 0,
130
+ b = 0,
131
+ a = 0;
132
+ for (var cy = 0; cy < side; cy++) {
133
+ for (var cx = 0; cx < side; cx++) {
134
+ var scy = sy + cy - halfSide;
135
+ var scx = sx + cx - halfSide;
136
+ if (scy >= 0 && scy < sh && scx >= 0 && scx < sw) {
137
+ var srcOff = (scy * sw + scx) * 4;
138
+ var wt = kernel[cy * side + cx];
139
+ r += src[srcOff] * wt;
140
+ g += src[srcOff + 1] * wt;
141
+ b += src[srcOff + 2] * wt;
142
+ a += src[srcOff + 3] * wt;
143
+ }
144
+ }
145
+ }
146
+ dst[dstOff] = r;
147
+ dst[dstOff + 1] = g;
148
+ dst[dstOff + 2] = b;
149
+ dst[dstOff + 3] = a + alphaFac * (255 - a);
150
+ }
151
+ }
152
+ return output;
153
+ }
154
+ const conv=(input,kernel,circular)=>{
155
+ if(input instanceof Matrix || (input instanceof Array && input[0][0]))return conv2d(input,kernel,circular);
156
+ return conv1d(input,kernel,circular)
157
+ }
158
+ const circularConv=(input,kernel)=>conv(input,kernel,true);
159
+ const linearConv=(input,kernel)=>conv(input,kernel,false);
160
+ const circularConv1d=(input,kernel)=>conv1d(input,kernel,true);
161
+ const circularConv2d=(input,kernel)=>conv2d(input,kernel,true);
162
+ const linearConv1d=(input,kernel)=>conv1d(input,kernel,false);
163
+ const linearConv2d=(input,kernel)=>conv2d(input,kernel,false);
164
+ export{
165
+ conv1d,
166
+ conv2d,
167
+ conv,
168
+ circularConv,
169
+ linearConv,
170
+ circularConv1d,
171
+ linearConv1d,
172
+ circularConv2d,
173
+ linearConv2d,
174
+ convolute
175
175
  }
@@ -1,55 +1,55 @@
1
- import { Complex , complex } from "../complex";
2
- import { PI } from "../const";
3
- import { cos , sin } from "../functions";
4
- const fft=x=>{
5
- const output = [];
6
- const N = x.length;
7
- if(!(x[0]instanceof Complex))x=x.map((n)=>complex(n,0));
8
- for (let k = 0; k < N; k++) {
9
- let re = 0,im=0;
10
- for (let n = 0; n < N; n++) {
11
- const phi = (2*PI * k * n) / N;
12
- re += x[n].a*cos(phi)+x[n].b*sin(phi);
13
- im += -x[n].a*sin(phi)+x[n].b*cos(phi);
14
- }
15
- re = re / N;
16
- im = im / N;
17
- output[k] = complex(re,im);
18
- }
19
- return {
20
- output,
21
- re:output.map(n=>n.a),
22
- im:output.map(n=>n.b),
23
- z:output.map(n=>n.z),
24
- phi:output.map(n=>n.phi)
25
- }
26
- }
27
- const ifft=x=>{
28
- const output = [];
29
- const N = x.length;
30
- if(!(x[0]instanceof Complex))x=x.map((n)=>complex(n,0));
31
- for (let k = 0; k < N; k++) {
32
- let re=0,im=0;
33
- for (let n = 0; n < N; n++) {
34
- const phi = (2*PI * k * n) / N;
35
- re += x[n].a*cos(phi)+x[n].b*sin(phi);
36
- im += x[n].a*sin(phi)+x[n].b*cos(phi);
37
- }
38
- re = re / N;
39
- im = im / N;
40
-
41
- output[k] = complex(re,im);
42
- }
43
- return {
44
- output,
45
- re:output.map(n=>n.a),
46
- im:output.map(n=>n.b),
47
- z:output.map(n=>n.z),
48
- phi:output.map(n=>n.phi)
49
- };
50
- }
51
-
52
- export{
53
- fft,
54
- ifft
1
+ import { Complex , complex } from "../complex";
2
+ import { PI } from "../const";
3
+ import { cos , sin } from "../functions";
4
+ const fft=x=>{
5
+ const output = [];
6
+ const N = x.length;
7
+ if(!(x[0]instanceof Complex))x=x.map((n)=>complex(n,0));
8
+ for (let k = 0; k < N; k++) {
9
+ let re = 0,im=0;
10
+ for (let n = 0; n < N; n++) {
11
+ const phi = (2*PI * k * n) / N;
12
+ re += x[n].a*cos(phi)+x[n].b*sin(phi);
13
+ im += -x[n].a*sin(phi)+x[n].b*cos(phi);
14
+ }
15
+ re = re / N;
16
+ im = im / N;
17
+ output[k] = complex(re,im);
18
+ }
19
+ return {
20
+ output,
21
+ re:output.map(n=>n.a),
22
+ im:output.map(n=>n.b),
23
+ z:output.map(n=>n.z),
24
+ phi:output.map(n=>n.phi)
25
+ }
26
+ }
27
+ const ifft=x=>{
28
+ const output = [];
29
+ const N = x.length;
30
+ if(!(x[0]instanceof Complex))x=x.map((n)=>complex(n,0));
31
+ for (let k = 0; k < N; k++) {
32
+ let re=0,im=0;
33
+ for (let n = 0; n < N; n++) {
34
+ const phi = (2*PI * k * n) / N;
35
+ re += x[n].a*cos(phi)+x[n].b*sin(phi);
36
+ im += x[n].a*sin(phi)+x[n].b*cos(phi);
37
+ }
38
+ re = re / N;
39
+ im = im / N;
40
+
41
+ output[k] = complex(re,im);
42
+ }
43
+ return {
44
+ output,
45
+ re:output.map(n=>n.a),
46
+ im:output.map(n=>n.b),
47
+ z:output.map(n=>n.z),
48
+ phi:output.map(n=>n.phi)
49
+ };
50
+ }
51
+
52
+ export{
53
+ fft,
54
+ ifft
55
55
  }
@@ -1,39 +1,39 @@
1
- import { complex } from "../complex/index.js";
2
- import {fft,ifft} from "./fft.js";
3
- // should be processed in other thread
4
- class Filter{
5
- constructor(input){
6
- this.input=input;
7
- this.input_fft=fft(this.input);
8
- this.output_fft=[]
9
- }
10
- // get length(){
11
- // return this.input.length;
12
- // }
13
- lowPass(fc){
14
- this.input_fft.output.forEach((n,i)=>{
15
- n=n.z<fc
16
- ? this.output_fft[i]=this.input_fft.output[i]
17
- : this.output_fft[i]=complex(0,0)
18
- })
19
- return ifft(this.output_fft).re;
20
- }
21
- highPass(fc){
22
- this.input_fft.output.forEach((n,i)=>{
23
- n=n.z>fc
24
- ? this.output_fft[i]=this.input_fft.output[i]
25
- : this.output_fft[i]=complex(0,0)
26
- })
27
- return ifft(this.output_fft).re;
28
- }
29
- bandePass(){
30
-
31
- }
32
- bandeCoupe(){
33
-
34
- }
35
- }
36
- const filter=input=>new Filter(input);
37
- export{
38
- filter
1
+ import { complex } from "../complex/index.js";
2
+ import {fft,ifft} from "./fft.js";
3
+ // should be processed in other thread
4
+ class Filter{
5
+ constructor(input){
6
+ this.input=input;
7
+ this.input_fft=fft(this.input);
8
+ this.output_fft=[]
9
+ }
10
+ // get length(){
11
+ // return this.input.length;
12
+ // }
13
+ lowPass(fc){
14
+ this.input_fft.output.forEach((n,i)=>{
15
+ n=n.z<fc
16
+ ? this.output_fft[i]=this.input_fft.output[i]
17
+ : this.output_fft[i]=complex(0,0)
18
+ })
19
+ return ifft(this.output_fft).re;
20
+ }
21
+ highPass(fc){
22
+ this.input_fft.output.forEach((n,i)=>{
23
+ n=n.z>fc
24
+ ? this.output_fft[i]=this.input_fft.output[i]
25
+ : this.output_fft[i]=complex(0,0)
26
+ })
27
+ return ifft(this.output_fft).re;
28
+ }
29
+ bandePass(){
30
+
31
+ }
32
+ bandeCoupe(){
33
+
34
+ }
35
+ }
36
+ const filter=input=>new Filter(input);
37
+ export{
38
+ filter
39
39
  }